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5 

BACKGROUND 

1 . FIELD OF THE INVENTION 

10 This invention relates to digital communication 

systems and, more particularly, to a detection system 
and method for an Ethernet receiver. 

2 . DISCUSSION OF RELATED ART 

15 

The dramatic increase in desktop computing power 
driven by intranet -based operations and the increased 
demand for time- sensitive delivery between users has 
spurred development of high-speed Ethernet LANs. 

2 0 10 0BASE-TX Ethernet, using existing category- 5 copper 

wire, and the newly developed 100 0BASE-T Ethernet for 
Gigabit/s transfer of data over category- 5 copper wire 
require new techniques in high speed symbol processing. 
Gigabit per second transfer can be accomplished 
25 utilizing four twisted pairs and a 125 megasymbol/s 

transfer rate on each pair where each symbol represents 
two bits. 

Physically, data is transferred using a set of 
voltages where each voltage represents one or more bits 

3 0 of data. Each voltage in the set is referred to as a 

symbol and the whole set of voltages is referred to as 
a symbol alphabet. In gigabit transfer, for example, 
data is usually sent with a set of five voltage levels 
(PAM-5) , each symbol representing two (2) bits. 
35 one system of transferring data at high rates is 

Non Return to Zero (NRZ) signaling. In NRZ, the symbol 
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alphabet {A} is {-1, +1}. A logical "1" is transmitted 
as a positive voltage while a logical "0" is 
transmitted as a negative voltage. At 125 M symbols/s, 
the symbol rate required for Gigabit transfer over four 
5 category-5 wires, the pulse width of each symbol is 8 
ns . 

Another example of a modulation method for high 
speed symbol transfer is MLT3 and involves a three 
level system. (See American National Standard 

10 Information system, Fibre Distributed Data. Interface 
(FDDI) -Part: Token Ring Twisted Pair Physical Layer 
Medium Dependent (TP-PMD) , ANSI X3 . 263 : 199X) . The 
symbol alphabet for MLT3 is {a}={ -1, 0, +l}. In MLT3 
transmission, a logical 1 is transmitted by either a -1 

15 or a +1 while a- logic 0 is transmitted as a 0 . A 

transmission of two consecutive logic "l"s does not 
require the system to pass through zero in the 
transition. A transmission of the logical sequence 
("1", "0", "1") would result in transmission of the 

20 symbols (+1, 0, -1) or (-1, 0, +1), depending on the 
symbols transmitted prior to this sequence. If the 
symbol transmitted immediately prior to the sequence 
was a +1, then the symbols (+1, 0, -1) are transmitted. 
If the symbol transmitted before this sequence was a 

25 -1, then the symbols (-1, 0, +1) are transmitted. If 

the symbol transmitted immediately before this sequence 
was a 0, then the first symbol of the sequence 
transmitted will be a +1 if the previous logical "1" 
was transmitted as a -1 and will be a -1 if the 

30 previous logical "1" was transmitted as a +1. 

The detection system in the MLT3 standard needs to 
distinguish between 3 voltage levels, instead of two 
voltage levels in a more typical two level system. The 
signal to noise ratio required to achieve a particular 

3 5 bit error rate is higher for MLT3 signaling than for 
two level systems . The advantage of the MLT3 system, 
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however, is that the energy spectrum of the emitted 
radiation from the MLT3 system is concentrated at lower 
frequencies and therefore more easily meets FCC 
radiation emission standards for transmission over 
5 twisted pair cables. Other communication systems may 
use a symbol alphabet having more than two voltage 
levels in the physical layer in order to transmit 
multiple bits of data using each individual symbol . 

In Gigabit Ethernet over twisted pair Category-5 

10 cabling, for example, PAM-5 data can be transmitted 

over four twisted copper pair at an individual twisted 
pair baud rate of 12 5 Mbaud. In PAM-5, data is sent 
with 5 voltage levels, designated as symbol alphabet 
{A}= {-2, -1, 0, 1, 2} although the actual voltage 

15 levels may be different from those. Each symbol, 

therefore, can be used to code more than one bit of 
data . 

Any other modulation scheme for symbol coding can 
be utilized, including quadrature amplitude modulation 
2 0 (QAM) . In QAM schemes, for example, the symbols are 
arranged on a two-dimensional (real and imaginary) 
symbol constellations (instead of the one-dimension 
constellations of the PAM-5 or MLT-3 symbol alphabets) . 

There is a need for transmitters and receivers for 

2 5 receiving transmission over multiple twisted copper 

pair using larger symbol alphabets (i.e., 3 or more 
symbols) . There is also a need for transceiver 
(transmitter/receiver) systems that, while operating at 
high symbol rates, have low bit error rates. 

30 

SUMMARY 

Accordingly, a receiver and detection method for 
receiving transmission of data over multiple wires 

3 5 using encoded data symbol schemes having multiple 

symbols is described. A receiver according to the 
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present invention includes multiple detectors for 
detecting one symbol from each of the multiple wires 
simultaneously (i.e., multiple 1-D detectors), an 
equalizer coupled to each of the detectors for 
5 equalizing the symbol stream from each of the multiple 
wires, and a multi-dimensional error analyzer/decoder 
for simultaneously making hard decision regarding the 
symbol output of the symbols transmitted over each of 
the multiple wires. 
10 Individual symbols can have any modulation scheme, 

including those with multi -dimensional constellations. 
The terminology of detecting N-dimensional symbols 
refers to the number of individual symbols detected in 
each clock cycle, and not to the dimension of the 
15 symbol constellation. 

Each of the equalizers can be any equalizer 
structure, including linear or decision feedback 
equalizers. In one embodiment of the invention, the 
equalizers include sequence detection equalizers. In 
20 another embodiment of the invention, the equalizers 
include simplified decision feedback equalizers. 

In another embodiment, the equalizer includes a 
sequence detection equalizer in combination with a 
linear equalizer or a decision feedback equalizer. In 
25 some embodiments, the sequence detection equalizer is a 
reduced state sequence detector. In some embodiments, 
the decision feedback equalizer is a simplified 
decision feedback equalizer. 

In general, a transceiver according to the present 
30 invention can utilize any symbol alphabet. In some 
embodiments, a PAM-5 symbol alphabet is utilized. 

Some embodiments of the invention can also include 
an error analysis decoder. The receiver receives 
signals from N individual wires and, for each wire, 
35 includes a linear equalizer in combination with a 1-D 

sequence detector. The N output signals from the N 1-D 
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sequence detectors are input to a N-D decoder that 
makes a final decision on the N-D symbol . In some 
embodiments of the invention, the error analysis 
decoder operates with lattice encoding schemes. In 
5 some other embodiments of the invention, the error 
analysis decoder operates with a parity encoding 
scheme . 

These and other embodiments of a transceiver 
system according to the present invention are further 
10 described below with reference to the following 
figures . 

BRIEF DESCRIPTION OF THE FIGURES 

15 Figure 1 shows a block diagram of a transceiver 

having multiple transport channels. 

Figure 2 shows a block diagram of an encoder 
capable of both trellis encoding and parity encoding. 

Figure 3 shows a trellis diagram for state 
20 transitions among subsets of PAM-5 4D symbols. 

Figure 4 shows a block diagram of a model of 
transmission channel between a transmitter and a 
receiver system. 

Figure 5A shows a block diagram of a N-D receiver 

2 5 system according to the present invention. 

Figure 5B shows a block diagram of a receiver 
according to the present invention for the N-D receiver 
system of Figure 5A. 

Figure 6 shows a block diagram of a linear 

3 0 equalizer. 

Figure 7 shows a block diagram of the equalizer 
and decoder portions of a 4-D receiver system that 
includes linear equalizers and parity encoding. 

Figure 8 shows a block diagram of a decision 
35 feedback equalizer. 
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Figure 9 shows a block diagram of the equalizer 
and decoder portions of a 4-D receiver system that 
includes decision feedback equalization. 

Figure 10 shows a block diagram of a 4-D receiver 
5 system that includes sequence detection equalizers. 

Figure 11A shows a block diagram of a sequence 
detector. 

Figure 11B shows a block diagram of an embodiment 
of an equalizer system. 
10 Figure 12 shows an example of a trellis diagram 

for state transitions between PAM-5 symbols. 

Figure 13 shows a block diagram of an embodiment 
of a sequence detector equalizer with decision feedback 
according to the present invention. 
15 Figure 14 shows a block diagram of an embodiment 

of a sequence detector equalizer having soft outputs 
according to the present invention. 

Figure 15 shows a block diagram of an embodiment 
of a parity code receiver that includes soft output 

2 0 sequence detection equalizers according to the present 

invention. 

Figure 16 shows an embodiment of a reduced 
complexity sequence detector having soft outputs 
according to the present invention. 
25 Figure 17 shows an example of a trellis diagram 

illustrating state changes between reduced states of a 
reduced complexity sequence detector, including 
multiple branches between states. 

Figure 18 shows a trellis diagram illustrating 

3 0 state changes between the reduced states of a reduced 

complexity sequence detector after branch path 
decisions have been made. 

Figure 19 shows a block diagram of a decision 
feedback equalizer having a simplified feedback section 
3 5 according to the present invention. 
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Figure 2 OA shows a sequence detector in 
combination with a decision feedback equalizer. 

Figure 2 OB shows an embodiment of the feedback 
section of the decision feedback equalizer shown in 
5 Figure 20A that includes a simplified feedback section. 

In the figures, components having similar 
functions are often labeled similarly. 



10 

DETAILED DESCRIPTION 

Figure 1 shows a block diagram of a transceiver 
system 100 according to the present invention. 

15 Transceiver system 100 includes transmitter 101, 

receiver 107, and transport wires 103-1 through 103-N. 
A digital data stream is input to transmitter 101 by a 
host 150. Transmitter 101 includes encoder 102, which 
encodes the data for transmission over transport wires 

20 103-1 through 103-N. Transmission coupler 112 couples 
the encoded symbols received from encoder 102 to 
transmission channel 104 . Data is output by 
transmission coupler 112 as symbols a k ,i through a k , N 
over wires 103-1 through 103-N, (collectively referred 

25 to as cable 103) , respectively, which are coupled 

between transmitter 101 and receiver system 107. Wires 
103-1 through 103-N can be of any transport medium or 
combination of transport media. Transport media 
include, for example, category- 5 twisted copper pair, 

30 optical fiber and coax cable. 

The index k in the above notation indicates the 
kth time cycle of the data transmission. The indicator 
N is an integer indicating the number of individual 
transport wires in cable 103. In general, any number 

35 of wires can be included in transceiver system 100. 
For gigabit transmission, N is usually four (4) , 
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indicating a four wire connection between transmitter 
101 and receiver system 107. Wires 103-1 through 103-4 
are often twisted copper pair. 

Transmission channel 104 collectively represents 
5 cable 103 and any distortion of the signals that occurs 
between transmitter 101 and a receiver 107. Each of 
wires 103-1 through 103 -N, along with output couplers 
of coupler 112 and input couplers of detector 108, 
distort signals as indicated by the associated 

10 transmission channel 104-1 through 104-N, respectively. 
The signals through wires 103-1 through 103 -N are 
distorted by channel functions fi(Z) through f N (Z), 
respectively, and additionally suffer from a random 
noise addition n k/i through n k , N , respectively. Receiver 

15 107 includes a signal detector 108 and a decoder 109 

and ultimately outputs a data stream which corresponds 
to the data stream entering transmitter 101. 

In Gigabit Ethernet, transmission can be conducted 
on four twisted copper pairs (i.e., wires 103-1 through 

20 103-4 in Figure 1) in a full duplex fashion to achieve 
one gigabit per second throughput. IEEE 802. 3ab, 
Gigabit Long Haul Copper Physical Layer Standards 
Committee, 1997 (hereinafter "Gigabit Standard") . 
Transmitter 101 is coupled to a first host 150 to 

2 5 receive data for transmission over transmission channel 
104 to a second host 151 coupled to receiver 107. In 
general, first host 150 is further coupled to a 
receiver 111 for receiving data from transmission 
channel 104 and second host 151 is coupled to a 

30 transmitter 110 for sending data to transmission 
channel 104. 

Although, in general, the detection system as 
described here is applicable to any scheme of data 
transmission (i.e., any symbol alphabet) over any 

35 number of transport wires (e.g., twisted copper pair), 
for exemplary purposes many of the examples below 
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specifically describe a PAM-5 symbol alphabet 
transmitted over four twisted copper pair, as would be 
used in Gigabit Ethernet transmission over Category- 5 
twisted pair cabling. It should be recognized that 
other symbol alphabets and numbers of conductors can 
also be used and that one skilled in the art will 
recognize from this disclosure embodiments appropriate 
for other modulation schemes . 



Encoder 

According to the developed IEEE 802. 3ab standard 
for Gigabit Ethernet transmission, the transmitted 
symbols on each of four conductors 103-1 through 103-4 
are chosen from a five level Pulse Amplitude Modulation 
(PAM-5) constellation, with alphabet {a}={-2, -1, 0, 
+1, +2}. See Gigabit Standard. At each clock cycle, a 
single one-dimensional (1-D) symbol is transmitted on 
each wire. The four 1-D symbols, one on each of 
conductors 103-1 through 103-4, transmitted at a 
particular sample time k, is considered to be a single 
4-D symbol. In general, data entering transmitter 101 
can be encoded into a N-D symbol, instead of into N 1-D 
symbols, by encoder 102. Encoder 102 may be any type 
of N-D encoder, including a N-D parity code encoder and 
a N-D trellis code encoder. 

To achieve one gigabit per second communications, 
a gigabit ethernet transceiver needs to achieve a 
throughput of 2 50 Megabits per second over each of four 
transport wires 103-1 through 103-4. Therefore, at a 
125 MHz baud rate, two bits must be transmitted at each 
sample time across each wire of cable 103 . Although a 
PAM-5 system is applicable, a four level PAM system, 
for example, does not provide redundancy which allows 
for error correction coding necessary to achieve a bit 
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error rate (BER) of 10" 10 , as required by the Gigabit 
Ethernet standard. See Gigabit Standard. 

In addition, extra channel symbols are needed to 
represent ethernet control characters. Therefore, five 
level PAM (PAM-5) with either a parity check code or 
trellis coding is often utilized in Gigabit Ethernet 
transmission. According to the Gigabit standard, the 
trellis code is the only coding utilized. Alphabets 
having more than five level 1-D symbols may also be 
utilized for Gigabit transmission while achieving the 
required BER. 

At 125 Mbaud, each 4-D symbol needs to transmit at 
least eight bits. Therefore, 256 different 4-D symbols 
plus those required for control characters are 
required. By transmitting a 4-D PAM-5 symbol alphabet, 
there are 5 4 = 625 possible symbols. This number of 
symbols allows for 100% redundancy in the data as well 
as for several control codes. Symbol alphabets having 
more than five symbols yield even greater redundancy. 
However, because of the difficulties in distinguishing 
between the higher number of voltage levels, higher 
error rates may be suffered in receiver detection 
systems, such as detector 108 of Figure 1. 

The Gigabit Ethernet standard. See Gigabit 
Standard, allows a trellis code. However, both a 4-D 
eight state trellis code and a 4-D parity code have 
been proposed. The trellis code achieves 6dB of coding 
gain over uncoded PAM-5 while the parity code achieves 
3dB of coding gain. While encoding, the choice between 
encoders can be encoded in a TX_CODING bit, which can 
be set to one for trellis coding. One skilled in the 
art will recognize that embodiments of the present 
invention are applicable to any error correction 
technique . 
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4D Trellis Encoding 

Trellis encoding in a conventional 4-D eight state 
code is described in Part II, Table IV of G. 
Ungerboeck, "Ungerboeck-Coded Modulation with Redundant 
Signal Sets, Part I and II", IEEE Communications, vol. 
24, no. 2, pp. 5-21 (Feb., 1987) (hereinafter 
"Ungerboech") . An embodiment of an eight state trellis 
encoder 200 similar to that described in Ungerboeck is 
shown in Figure 2. Trellis encoder 200 receives eight 
bits, bits 0 through 7, and outputs 9 bits, bits 0 
through 7 plus a parity bit, provided that TX_CODING is 
set to 1. The parity bit is produced from a rate 2/3 
memory 3, systematic convolutional encoder 201. 

Convolutional encoder 201 includes delays 202, 204 
and 206, each of which delays its input signal by one 
clock cycle. The output signal from delay 202 is XORed 
(exclusive -ORed) with bit 6 in XOR 2 03 and input to 
delay 204. The output signal from delay 204 is XORed 
with bit 7 in XOR 205 and input to delay 206. The 
output signal from delay 206 is input to AND gate 207 
and input to delay 202. AND gate 207 generates the 
parity bit, which is one (1) if TX_CODING is one (1) 
and the output signal from delay 2 06 is 1, and zero 
otherwise. In embodiments that only utilize trellis 
coding (i.e., TX_C0DING is always 1), AND gate 207 may 
be excluded from encoder 200 and the parity bit is the 
output signal from convolutional encoder 201. 

The two input bits to convolutional encoder 2 01 
(bits 6 and 7) , and the parity bit produced by encoder 
201 select one of eight subsets, DO through D7 , of the 
4-D symbol alphabet. The nine output bits are mapped 
to one 4-D PAM-5 symbol that is then transmitted across 
cable 103 (Figure 1) as four 1-D PAM-5 symbols. 

Each 1-D PAM-5 symbol is a member of one of two 
families, X (odd) and Y (even) . The odd set X contains 
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the PAM-5 symbols {-1, +l} and the even set Y contains 
the PAM-5 symbols {-2, 0, +2}. Table 1 shows a 
definition of the eight subsets of 4-D symbols labeled 
DO through D7 . The definition is based on the 
5 membership of 1-D PAM-5 symbols that are represented in 
each subset. Table 1 also shows the number of 4-D 
symbols included in each of the subsets. 

The notation describing each subset indicates the 
families of 1-D PAM-5 symbols on each of the four wires 

10 describing membership in that subset. The notation 
XXYX, for example, indicates a set of four 1-D PAM-5 
symbols where the first symbol is from type X, the 
second symbol is from type X, the third symbol is from 
type Y, and the fourth symbol is from type X. 

15 Therefore, conductor 103-1 (Figure 1) carriers a symbol 
of type X, conductor 103-2 carries a symbol of type X, 
conductor 103-3 carries a symbol of type Y and 
conductor 103-4 carries a symbol of type X. 

2 0 Table 1 -- Mapping of 4-D symbols into sets DO through 
D7 . 



Subset 


X Primary Code 


Y Primary Code 


# of 
Symbols 


DO 


XXXX 


YYYY 


97 


Dl 


XXXY 


YYYX 


78 


D2 


XXYY 


YYXX 


72 


D3 


XXYX 


YYXY 


78 


D4 


XYYX 


YXXY 


72 


D5 


XYYY 


YXXX 


78 


D6 


XYXY 


YXYX 


72 


D7 


XYXX 


YXYY 


78 



The parity bit and bits 6 and 7 are input to set 
select 210 (Figure 2) . Set select 210 determines a 
25 particular subset selection p, indicating that subset D P 



-12- 



612675 v3 



of subsets D 0 through D 7 has been selected. In one 
embodiment, subset selection p is determined according 
to the formula 

p = 4*BIT6 + 2*BIT7 + l*Parity, (D 

where BIT6 is bit 6, BIT7 is bit 7, and Parity is the 
parity bit. 

A point within subset p is chosen by the six least 
significant bits of the input, bits 0 through 5. Bits 
0 through 5 are input to a 4-D PAM-5 mapper 211 along 
with the output of set select 210, x- 4 - D PAM-5 mapper 
211 determines the 4-D PAM-5 symbol within set D p which 
represents the eight input bits, bits 0 through 7, and 
the parity bit. Each subset, DO through D7 , contains 
more than the 64 points required to encode the six 
bits, bits 0 through 5. These additional points are 
either used as control characters or not used at all. 

The subset mapping shown in Table 1 is chosen such 
that the squared Euclidean distance between any pair of 
points in the same subset is greater than or equal to 
four (4) . For example, the squared distance between 
two points in subset DO can be expressed as (Xn-Xi 2 ) **2 
+ (X 21 -X 22 )**2 + (X 31 -X 32 )**2 + (X41-X42) **2. Because X ±j = 
+2, 0, or -2, the shortest squared distance is (2-0) **2 
= 4, which occurs when only one value differs between 
the two points. In addition, the squared Euclidean 
distance between points in different even subsets is 
greater than or equal to 2 and the squared Euclidean 
distance between points in different odd subsets is 
greater than or equal to 2 . As also can be seen from 
Table 1, even numbered subsets (D 0 , D 2 , D 4 , D 6 ) have an 
even number of symbols of type X and an even number of 
symbols from type Y while odd numbered subsets (Di, D 3 , 
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D 5/ D 7 ) have an odd number of symbols of type X and an 
odd number of symbols of type Y. 

Figure 3 shows a trellis diagram resulting from 
the convolutional encoder shown in Figure 2. The 
states of the trellis in Figure 3, S 0 through S 7 , are 
determined by the bits in delay elements 202, 204 and 
206. The state S q is determined by q=4* (the output 
signal from delay 202) +2* (the output signal from delay 
204) + 1* (the output bit from delay 206). The subsets 
Dp are determined by the transition from one state to 
another as shown in Figure 3 . The subsepts D p are given 
in Table 1 . 

As shown in Figure 3, all transitions out of a 
particular state are either all even substates (D 0 , D 2 , 
D 4 , and D 6 ) or all odd subsets (D x , D 3 , D 5 , and D 7 ) . 
Similarly, the transitions into a particular state are 
either all even subsets or all odd subsets. The 
minimum squared distance between outgoing transitions, 
therefore, is equal to two (2) and the minimum squared 
distance between incoming transitions is also two (2) . 

As a result, the minimum squared distance between 
valid sequences is greater than or equal to 4, which 
can be seen from the fact that any two paths that 
originate from the same node and end at the same node, 
but diverge at some point in the middle, must then 
converge at a later time. Both the divergence and the 
convergence have a squared distance of at least 2, thus 
the total squared distance must be at least 4 . In the 
case where these two paths do not diverge, then they 
must contain different points from the same subset. 
Because the minimum squared distance between points in 
the same subset is equal to 4, the minimum squared 
distance between valid sequences is 4 . As is 
conventionally known, therefore, a coding gain of 6dB 
with respect to uncoded PAM-5 constellations are 
experienced . 
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4D Parity code 

5 The 4-D parity code can also be transmitted using 

the same encoder, encoder 2 00 of Figure 2. To do so, 
the TX_C0DING bit is set to zero. As a result, the 
parity bit produced by convolutional encoder 201 is 
always 0. Therefore, set select 211 always chooses 
10 even subsets (i.e., X=0, 2, 4 or 6) . The minimum 

squared Euclidean distance between any two 4-D symbols, 
therefore, is 2 and a coding gain of 3dB is experienced 
over uncoded PAM-5. 

15 Transmitter Coupler 

Transmitter coupler 112 (Figure 1) couples the N-D 
symbol from encoder 102 to transmission channel 104. 
In some embodiments, coupler 112 can include pre-coding 

20 of signals to each of lines 103-1 through 103-N. Some 
pre-coding may at least partially overcome the expected 
intersymbol interference effects experienced in 
transmission channels 104-1 through 104 -N, 
respectively. However, some pre-coding, such as partial 

2 5 response shaping, for example, may actually add to the 
intersymbol interference effects. 

Coupler 112 converts symbols received from encoder 
102 to appropriate voltages for transmission to 
receiver 107 through transmission channel 104. In many 

30 embodiments of PAM-5 transmission, for example, those 
voltages are (-1, -1/2, 0, +1/2, +1) volts 
corresponding to the PAM-5 symbols (-2, -1, 0, 1, 2), 
respectively . 

35 Transmission Channel Characteristics 
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An input symbol stream {a k/1 } through {a k , N } is 
input to each of wires 103-1 through 103 -N, 
respectively, of transmission channel 104 (Figure 1) by 
transmitter 101. Wires 103-1 through 103 -N can be 
5 twisted copper pair, or some other transmission medium 
such as coaxial cable or optical fiber. Transmission 
channel 104 represents the effects that wires 103-1 
through 103 -N, transmission coupler 112 and receiver 
couplers in detector 10 8 have on the input symbol 
10 streams {a k ,i} through {a k/K }in transmission between 

transmitter 101 and receiver 107. Each transmission 
channel 104-1 through 104 -N includes a corresponding 
one of wires 103-1 through 103 -N, respectively, for the 
symbol stream {a k ,i} through {a k , N , } respectively. 
15 Figure 4 shows a single transmission channel 104 -L 

that represents the Lth one of transmission channels 
104-1 through 104 -N, where L can be any one of 1 
through N. The symbol a k , L , representing the symbol 
transmitted on wire 103 -L in the kth time period, is 
2 0 transmitted through transmission channel 104 -L. The 

symbol stream {a k , L } of Figure 4 can be NRZ, MLT3 , PAM-5 
or any other symbol alphabet and modulation. The 
transmitted symbols in the sequence {a k , L } are members 
of the symbol alphabet {a} . In the case of five-level 
25 PAM signaling, the symbol alphabet {A} is given by {-2, 
-1, 0 +1, +2} . 

The channel response 105-L is represented by the 
channel function f L (z). In Figure 1, each of conductors 
103-1 through 103 -N can experience a different channel 
30 function f x (Z) through f N (Z), respectively. The 

addition of random noise n k , L in Figure 4 is represented 
by adder 106 -L. Again, in Figure 1 each of conductors 
103-1 through 103 -N experiences a different random 
noise n k ,i through n k/N , respectively. The signal, x k , L 
35 suffering from channel distortion, random noise, and a 
flat signal loss, is received by a receiver 107. 
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For the sake of simplicity, a baseband 
transmission system is assumed, although the techniques 
shown are easily extended to a passband transmission 
system. (See E.A. Lee and D.G. Messerchmitt , Digital 
5 Communications (1988)) It is also assumed that the 
channel model includes the effects of transmit and 
receive filtering. In addition, the transmission 
channel is assumed to be linear in that two overlapping 
signals simply add as a linear superposition. The Z- 
10 transform, (see A. V. Oppenheim & R. W. Schafer, Discrete- 
Time Signal Processing (1989)), of the sampled transmission 
channel 104 -L shown in Figure 4 is given by the channel 
function polynomial 

15 f L (Z)=f 0 , L + fi^Z" 1 + . . . fj, L Z" j + . . . + f R , L Z"" R , (2) 

where f 0/L , f j/L , f r,l are the polynomial 

coefficients. The coefficient f jyL represents the 
dispersed component of the (k-j)th symbol present in 

20 the a k , L th symbol and R is a cut-off integer such that 
fj,L for j>R is negligible. The polynomial f L (Z) 
represents the Z- transformation of the frequency 
response of the transmission channel (Z _1 represents a 
one period delay) . (See A. V. Oppenheim & R. W. Schafer, 

2 5 Discrete -Time Signal Processing (1989) ) . 

The noiseless output of the channel at sample time 
k is given by 

r k ,L = fo,L * a k , L + fi, L * a k _i, L + . . . f R , L * a k - R , L , (3) 

30 

where, without loss of generality, f 0 ,L can be assumed 
to be 1. Thus, the channel output signal at time k 
depends, not only on transmitted data at time k, but on 
R past values of the transmitted data. This effect is 
35 known as "intersymbol interference" (ISI) . (See Lee & 
Messerschmitt) . The ISI length of the transmission 
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channel defined by Equations 2 and 3 is R, the number 
of past symbols contributing to ISI . 

Intersymbol interference is a result of the 
dispersive nature of the communication channel . The 
IEEE LAN standards require that systems be capable of 
transmitting and receiving data through at least a 100 
meter cable. In many instances, a single symbol may 
affect symbols throughout the transmission cable. 

The noise element of the input signal is 
represented by the sequence {n k , L } - Therefore, the 
noisy output signal from transmission channel 104 -L is 
given by 

x k ,i=r k , L + n k , L , (4) 

where the noise samples {n k/L } are assumed to be 
independent and identically distributed Gaussian random 
variables (see Lee & Messerschmitt) with variance equal to 
cr 2 . 

Receiver 

Figure 5A shows in a block diagram an embodiment 
of a baseband receiver system 5 00 according to the 
present invention. Other receiver systems may also 
utilize aspects of the present invention. Embodiments 
of receiver system 500 may include any number of 
transport wires 103-1 through 103 -N (with associated 
transmission channels 104-1 through 104 -N, 
respectively) carrying input signal streams x k ,i through 
x k/N , respectively. 

Receiver system 500 includes receivers 501-1 
through 501 -N, one for each of lines 103-1 through 103- 
N, respectively. Receiver 501-j, an arbitrarily chosen 
one of receivers 501-1 through 501-N, includes 
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filter/digitizer 502-j, equalizer 505-j, and 
coefficient update 506-j . Signals from wire 103-j, 
x k ,j, are received by filter digitizer 502-j. 
Filter/digitizer 502-j filters, digitizes and amplifies 
5 the signal x k ,j and outputs a signal y kfj . Equalizer 

505-j receives the signal y k ,j, equalizes it to remove 
the effects of intersymbol interference, and outputs a 
signal a' k(j , which is the output signal for receiver 
501-j. Filter/Digitizer 502-j can be arranged to 
10 include filters that partially remove the ISI 

interference from signal x kjj before digitizing the 
signal. (See, e.g., Application Serial No. [Attorney 
Docket No. M-5789] , filed on the same date as the 
present application, and assigned to the same assignee 
15 as is the present application, herein incorporated by 
reference in its entirety) . 

Coefficient update 506-j inputs decided on symbols 
a k<j and other parameters and adaptively chooses 
parameters for filter/digitizer 502-j and equalizer 
20 505-j (e.g., amplifier gain, multiplier coefficients, 
filter parameters, echo cancellation, NEXT 
cancellation, and timing parameters) . 

One skilled in the art will recognize that each of 
receivers 501-1 through 501-N can be dif f erent (i . e . , 
25 each of filters 502-1 through 502-N and equalizers 505- 
1 through 505-N can be individually matched to receive 
input signals from the corresponding one of wires 103-1 
through 103 -N. 

Figure 5B shows a representative example receiver 
30 501-j . Receiver 501-j is one of receivers 501-1 
through 501-N. Receiver 501-j includes 

receiver/digitizer 502-j in series with equalizer 505- 
j . Receiver/digitizer 502-j includes, in series, 
filters/echo cancelor 508-j , analog- to-digital 
35 converter (ADC) 509- j , and amplifier 510- j . One 

skilled in the art will recognize that the order of 
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these components can be altered. For example, 
amplifier 510-j can be implemented before filter 502-j 
or filter/echo canceller 508 -j can be implemented, 
completely or partially, digitally after ADC 509-j . 
5 Parameters to control the components of receiver 

502-j can be adaptively chosen by coefficient update 
506-j . Coefficient update 506-j adaptively determines 
the equalizer coefficients of equalizers 505- j, the 
gain gj of amplifier 510-j, the timing coefficient Tj of 
10 ADC 509-j, and filter coefficients for filter 508-j. 
In some embodiments, coefficient update 506-j can 
calculate a baseline wander correction signal, which is 
subtracted from the output sample of ADC 509-j at 
baseline wander correction adder 511-j . Baseline 
15 wander correction is discussed in "Digital Baseline 

Wander Correction Circuit," U.S. Patent Application No. 
09/151,525, filed July 11, 1998, Sreen A. Raghavan, 
assigned to the same assignee as the present 
disclosure, herein incorporated by reference in its 
20 entirety. 

Some embodiments of receiver 501 -j include a cable 
quality and length indicator 512 -j that indicates a 
wire length L and wire quality Q. 

Echo noise, which is a result of impedance 
2 5 mismatches in the duplex link causing some of the 

transmitted signal energy to be reflected back into a 
receiver, and near end crosstalk (NEXT) noise, which is 
caused by the interference from a transmitter 110 
(Figure 1) physically located adjacent to receiver 107, 
30 can be canceled through adaptive algorithms in filter 
508-j . The cancellation of echo noise and NEXT noise 
is nearly complete because receiver system 500 has 
access to the data transmitted by an adjacent 
transmitter (transmitter 110 in Figure 1) . Coefficient 
35 update 506-j, therefore, may input parameters from a 
decoder/slicer, host 151 or other controller in order 
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to adjust filter 508- j to cancel echo and NEXT noise. 
Note that, in Figure 1, transmitter 101 may also be 
adjacent to an accompanying receiver 111. 

Filter 508-j can also include an anti-aliasing 
filter. An anti-aliasing filter prevents aliasing by 
passing the input signal, received from wire 103-j, 
through a low pass filter to reject out -of -band noise. 
As such, any conventional anti-aliasing filter can be 
utilized as an anti-aliasing filter portion of filter 

508- j . 

The analog-to-digital converter (ADC) 509-j 
samples and holds the input signal for a duration of 
the symbol period T, which in one embodiment of the 
invention is 8 ns . In general, embodiments of the 
invention can utilize any symbol period. Techniques 
for analog-to-digital conversion that can be used in 
ADC 509-j are well known. The digitized signals in the 
receiver are interchangeably referred to in this 
disclosure as samples or signals. 

Amplifier 510-j amplifies the samples received 
from wire 103-j through transmission channel 104- j in 
order to correct for signal loss during transmission. 
The gain of amplifier 510-j, g-j, can be adaptively 
chosen by coefficient update 506-j in order to optimize 
the operation of receiver 501-j . One of ordinary skill 
in the art will recognize that digital amplifier 510-j 
can be located anywhere in receiver 5 02 -j between ADC 

509- j and equalizer 505-j . In general, amplifier 510-j 
can also be an analog amplifier located anywhere 
between input channel 104 -j and ADC 509-j . 

In some embodiments, coefficient update 506-j can 
also calculate the length and quality of wire 103-j. 
Cable length and quality determination is discussed in 
U.S. Patent Application No. 09/161,346, "Cable Length 
and Quality Indicator", filed September 25, 1998, 
Sreen A. Raghavan and Doug J. Easton, assigned to the 
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same assignee as the present disclosure, herein 
incorporated by reference in its entirety. 

The output sample from receiver/digit izer 502-j, 
y k;j , is input to equalizer 505-j . Equalizer 505-j can 

5 be any kind of equalizer structure. Types of equalizer 
structures include linear equalizers, decision feedback 
equalizers, and sequence detection equalizers. 
Equalizers of these types for 100 or 1000 BASE-T 
Ethernet over category- 5 wiring, 24 gauge twisted 

10 copper pair, are described in "Improved Detection for 
Digital Communication Receivers," U.S. Application No. 
08/974,450, filed November 20, 1997, Sreen A. Raghavan, 
assigned to the same assignee as the present 
application, herein incorporated by reference in its 

15 entirety; and "Simplified Equalizer for Twisted Pair 
Channel," U.S. Application No. 09/020,628, filed 
February 9, 1998, Sreen A. Raghavan, assigned to the 
same assignee as the present disclosure, herein 
incorporated by reference in its entirety. 

2 0 Additionally, receivers of the type described 

above as receivers 501-1 through 501-N are further 
described in "Digital Baseline Wander Correction 
Circuit," U.S. Application No. 09/151,525, filed July 
11, 1998, Sreen A. Raghavan; and U.S. Patent 

25 Application No. 09/161,346, "Cable Length and Quality 
Indicator", filed September 25, 1998, Sreen A. 
Raghavan and Doug J. Easton, both of which have already 
been incorporated by reference. 

In receiver system 50 0 of Figure 5A, the output 

30 samples from each of receivers 501-1 through 501-N, a k ,i 
through a' k , N , are input to decoder 507. Decoder 507 
decides on a N-D symbol based on the samples from each 
of receivers 501-1 through 501-N. Each of the N 1-D 
symbols of the N-D symbol is the result of the N-D 

35 symbol pick in decoder 507. 
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Figure 6 shows a block diagram of a linear 
equalizer 600 having R+l multipliers, where R is any 
integer greater than or equal to 0. Linear equalizer 
600 includes delays 601-1 through 601-R connected in 
5 series. The output samples from each of delays 601-1 
through 601-R is also input to multipliers 602-1 
through 602-R, respectively. The input sample to 
equalizer 600 is input to multiplier 602-0. The input 
samples to multipliers 602-0 through 602-R are 

10 multiplied by the corresponding one of multiplier 

coefficients C 0 through C R , respectively, and summed in 
adder 603. Multiplier coefficients C 0 through C R can be 
adaptively chosen to optimize the performance of 
equalizer 600. In Figure 5B, for example, coefficient 

15 update 506-j adaptively chooses equalizer parameters 
for equalizer 505-j . 

Equalizer 600 (Figure 6) executes the transfer 
function 

T=C Q + QZ' 1 + ■■■+C J Z- J +■■■ + C R Z- R . (6) 

20 For simplicity, the wire designation L has been 

neglected. It is understood that each transmission 
channel includes a separated equalizer, each of which 
can be one of equalizer 60 0 having its own transfer 
function T. 

25 In a zero-forcing linear equalizer (ZFLE) , the 

transfer function T is the inverse of the frequency 
response of the channel f (Z) (see Equation 2 with the 
wire designation L neglected) . In a minimum mean 
squared error based linear equalizer (MMSE-LE) , the 

3 0 transfer function is arranged to optimize the mean 

squared error between the transmitted data signal and 
the detected data symbols. A compromise, then, is 
found between the un-canceled ISI and the noise 
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variance at the output terminal of the equalizer. (See 
B. Sklar, Digital Communications, Fundamentals and Applications 
(PTR Prentice Hall, Englewood Cliffs, N J , 1988)). 
The output sample from linear equalizer 600, 
5 executing transfer function T, is given by 

< = Qy* + Q^-i + ••• + Cpk-j + + • (7) 

where C 0 through C R are the equalizer coefficients, y k -j 
is the input signal to equalizer 600 during the time 
period j periods before the kth period, and k 

10 represents the current time period. 

The output sample from equalizer 60 0, a' k , is 
usually input to a slicer 604 which decides, based on 
its input sample a' k , what symbol a k was transmitted 
during time period k. The symbol a k is chosen from the 

15 symbol alphabet used for transferring data that is 
closest to input signal a' k . 

A linear equalizer can be implemented using either 
parity coding or trellis coding systems. When linear 
equalization is used with parity coding, a separate 

20 linear equalizer is used on each transport wire. In 
Figure 5A, for example, each of equalizers 505-1 
through 505 -N can include a linear equalizer. The 
output samples from each of equalizers 505-1 through 
505 -N is input to decoder 507, which chooses the most 

2 5 appropriate multi -dimensional (N-D) symbol 

As an example, Figure 7 shows a portion of a 4-D 
receiver system 710, which includes 4-D decoder 700 and 
linear equalizers 600-1 through 600-4. Linear 
equalizers 600-1 through 600-4 provides equalization 

30 for each of channels 104-1 through 104-4, respectively. 
Decoder 700 can be any type of decoder including a 
parity code decoder and a 4-D trellis decoder. As an 
example, decoder 700 is shown as a parity code decoder. 
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Also, although a 4-D decoder is shown in Figure 7, it 
is understood that in general receiver system 710 can 
have any number of parallel input signals. 

The input samples to linear equalizers 600-1 
through 600-4, corresponding to the output samples from 
receiver/digitizer 502-1 through 502-4 (Figure 5B) , 
which is given by y k> i through y k , 4 samples, 
respectively. The subscripts 1-4 reference each of the 
four wires 103-1 through 103-4, respectively. The 
output samples from linear equalizers 600-1 through 
600-4 are given by a' k ,i through a' k , 4 , respectively, and 
are input to slicers 604-1 through 604-4, respectively. 
In Figure 7, slicers 604-1 through 604-4 are 1-D 
slicers. If PAM-5 symbol coding is utilized, then 
slicers 604-1 through 604-4 are 1-D PAM-5 slicers that 
each output the PAM-5 symbol closest to input sample 
a' k ,i through a' k , 4 , respectively. 

The output symbols from slicers 604-1 through 604- 
4, a k , x through a k , 4 , respectively, are input to parity 
check 702. Additionally, each of samples a' k(1 through 
a' k<4 is subtracted from the corresponding one of symbols 
a k ,i through a k , 4 , respectively, in adders 701-1 through 
701-4, respectively, to calculate errors e k ,i through 
e k;4 , respectively. In general, then, the error signal 
e k(i , where i is 1 through 4, is given by 

e k,i= a 'k,i - ■ (8) 

The parity of the 4-D symbol that results from the 
four ID symbols is checked in parity check 702. In 
parity coding, the 4D symbol is chosen from an even 
subset of all 4-D symbols. Therefore, if PAM-5 coding 
is used, there are an even number of PAM-5 symbols from 
family X (odd symbols) and an even number from family Y 
(even symbols) . Parity check 702 checks the parity of 
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the four input symbols, a k ,i through a k , 4 , by determining 
whether the sum of the four symbols is even or not . An 
odd parity indicates that there is an error in at least 
one of the decided symbols a k ,i through a kj4 . The result 
of the parity check is input to final decoder 704. 

The calculated error signals e k ,i through e k/4 are 
input to error analysis 703. Error analysis 703 
determines which of the four error signals e k<i through 
e k/4 is greatest and the sign of that error. Error 
analysis 703 outputs a sign signal (sgn) and an 
identifier for the symbol having the greatest error 
(W) . 

Final decoder 7 04 inputs the parity signal from 
parity check 702, the four 1-D PAM-5 symbols from 
slicers 604-1 through 604-4, a k(1 through a k/4 , 
respectively, the identifier for the symbol having the 
greatest error, W, and the sign of that error, sgn, and 
outputs the PAM-5 symbols a' k ,i through a' k , 4 in response. 
If the parity is even, then the 4-D symbol defined by 
a' k ,i through a' k , 4 is given by a k ,i through a k , 4 , 
respectively. The parity coding scheme, therefore, 
will pass erroneous 4D symbols containing simultaneous 
errors in two of the 1-D symbols. 

If the parity is odd, however, the results of 
error analysis 7 03 are used to correct the output 
symbols. Because the symbol having the greatest error 
is the one that is most likely incorrect, the value of 
the symbol indicated by identifier W is corrected by 
either increasing or decreasing that symbol by one 
symbol in the symbol alphabet in response to the sign 
of the error (in this example, increased for a positive 
sign and decreased for a negative sign) . The new set 
of four symbols, the three uncorrected symbols having 
the lowest error and the corrected symbol, is output as 
the 4-D symbol defined by a' k ,i through a' k(4 . 



Although simple to implement, the primary 
disadvantage of a linear equalizer is that, while 
removing the ISI from the input signal, it may cause 
the random noise to be enhanced. This is especially 
true in twisted copper pair channels where the 
frequency response of the channel has significant 
attenuation across the transmitted signal bandwidth. 
Hence, in twisted-pair channels, such as is used with 
gigabit ethernet, linear equalization often does not 
perform well enough to be practical. 

Figure 8 shows a decision feedback equalizer 800. 
Decision feedback equalizer 800 includes a feed-forward 
section 810, a feedback section 811 and adder 804. 
Feedforward section includes delays 801-1 through 801-M 
coupled in series, multipliers 802-1 through 802-M 
coupled to receive the output signals from delays 801-1 
through 801-M, respectively, multiplier 802-0 coupled 
to receive the input sample to decision feedback 
equalizer 800, and adder 803 coupled to receive the 
output signals from each of multipliers 8 02-0 through 
802-M. The output signal from each of multipliers 802- 
0 through 802-M is the input signal to that multiplier 
multiplied by the corresponding one of feed- forward 
multiplier coefficients C 0 through C M . Feed- forward 
multiplier coefficients C 0 through C M can be adaptively 
chosen in order to optimize the performance of the 
equalizer. In Figure 5B, for example, coefficient 
update 506 -j adaptively chooses equalizer coefficients 
to optimize the performance of receiver 501-j . 

Adder 803 (Figure 8) sums the output signals from 
each of multipliers 802-0 through 802-M. Feedforward 
section 810, therefore, executes the transfer function 



T FF = C Q + C x Z~ l +■■■ + CjZ- j +■■■ + C M Z~ M . 



(9) 



The output signal from feedforward section 810, 
therefore, is given by 



< = Qy k + C,y k _, +■■■ + Cjy k _j + ■■■ + C M y k _ M , (10) 

where y k .j is the input sample to equalizer 800 during 
5 the (k-j)th time period. Again, the wire designation 
has been neglected for simplicity and it is understood 
that each of receivers 501-1 through 501-N (Figure 5) 
includes an equalizer 505-1 through 505 -N, 
respectively, any of which can be a decision feedback 

10 equalizer 800 (Figure 8) . 

One embodiment of feedback section 811 includes 
delays 805-1 through 805-P coupled in series. 
Multipliers 806-1 through 806-P are coupled to receive 
the corresponding output signals from delays 805-1 

15 through 805-P, respectively. Multipliers 806-1 through 
806-P multiply each of their input signals by the 
corresponding one of feedback multiplier coefficients Bi 
through B P , respectively. Feedback coefficients B x 
through B P also can be adapt ively chosen. Adder 8 07 

2 0 sums the output signals from each of multipliers 806-1 
through 806-P. Feedback section 811, therefore, 
executes the transfer function 

T FB =B X Z-' +B Z Z' 2 + -- + B P Z~ P . (ID 

Because the input signal to feedback section 811 is 
2 5 symbol a k , the output signal from feedback section 811 
is given by 



a" = B x a k _ x + B 2 a k _ 2 H h B N a k _ p 
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A second embodiment of feedback section 811, which 
is later discussed in this disclosure, is shown as 
feedback section 1905 in Figure 19 and includes look-up 
table 1906. 

5 The output signal from feedback section 811, a k , 

is subtracted from the output signal from feedforward 
section 810, a' k , in adder 804. The input signal to 
slicer 808, then, is given by 



10 Slicer 808 outputs the symbol a k that is closest to the 
input s ignal a" ' k . 

A decision feedback equalizer operates on the 
principle that if the past transmitted data is 
correctly detected, then the ISI effects of these past 

15 data symbols can be canceled from the currently 

received sample. As such, often feedforward section 
810 contains no multipliers (i.e., C 0 = 1 and all other 
coefficients are 0) and a' k = y k , the input sample. 

Past detected data samples contain no noise and 

2 0 therefore decision feedback equalizers do not suffer 
from noise enhancement. However, decision feedback 
equalizers do suffer from the effects of error 
propagation. If slicer 808 erroneously decides a 
previous symbol, the error will be propagated into 

25 subsequent decisions. 

Figure 9 shows the equalization and decoder 
sections (see Equalizers 505-1 through 505-4 and 
decoder 507 of Figure 5, for example) of a 4D receiver 
910. The equalization is accomplished using four 

30 decision feedback equalizers, one for each of the four 
input channels shown. Again, one skilled in the art 
will recognize that a receiver can have any number of 
input channels and that a 4-D receiver is shown here 
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for example only. In Figure 9, receiver 910 includes 
4-D decoder 900. Although decoder 900 is shown as a 
Parity code decoder, it is understood that decoder 90 0 
can be any 4-D decoder. One skilled in the art will 
5 recognize that 4-D decoder 900 must correct symbols 

within a single clock cycle so that the results can be 
fed back through FB taps 811-1 through 811-4 to correct 
symbols a' k ,i through a' k , 4 , respectively. 

The equalization for channel 104-1, for example, 
10 is accomplished by feedforward section 810-1, feedback 
section 811-1, and adder 804-1. Similarly, channels 
104-2 through 104-4, each includes the corresponding 
ones of feedforward taps 810-2 through 810-4, 
respectively, feedback taps 811-2 through 811-4, 
15 respectively, and adders 804-2 through 804-4,^ 
respectively. 

Samples y k ,i through y k , 4 originate from receiver 
input signals received from channels 104-1 through 104- 
4, respectively. Samples y k ,i through y k , 4 are received 
2 0 into feedforward taps 810-1 through 810-4, 

respectively. The symbol outputs from decoder 900, a k ,i 
through a' k , 4 , corresponding to a single 4-D symbol, are 
input to feedback taps 811-1 through 811-4, 
respectively. As was discussed with relation to Figure 
25 8, the output signals from each of feedback sections 
811-1 through 811-4, a" k ,i through a" kf4 , respectively, 
is subtracted from the corresponding one of the output 
signals from feedforward sections 810-1 through 810-4, 
a' k ,i through a' k , 4 , respectively, in adders 804-1 through 
30 804-4, respectively. The output signals from adders 

804-1 through 804-4, a'" k(1 through a'" k/4 , respectively, 
are inputted to decoder 900. 

In an embodiment where decoder 90 0 is a 4-D parity 
code decoder, the input signals to decoder 900, a'" k ,i 
35 through a"' k , 4/ are received by slicers 901-1 through 
901-4, respectively. Each of slicers 901-1 through 
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901-4 decides on an output symbol, a k/i through a k/4 , 
respectively, based on its corresponding input signal, 
a"'k,i through a"' k ,4, respectively. The output symbols 
from slicers 901-1 through 901-4 are inputted to parity 
5 check 903 and final decoder 905. 

Parity check 903 sums the ID symbols a k ,i through 
a k , 4 and determines whether the 4D symbol is of even 
parity or odd parity. In parity coding using PAM-5 
symbols, the 4D symbol is chosen from an even subset 

10 and therefore each 4D symbol includes an even number of 
1-D PAM-5 symbols from family X (odd parity) and an 
even number from family Y (even parity) . Therefore, 
the sum of the 1-D PAM-5 symbols is even. If the 
parity of the 4-D symbol is even, then final decoder 

15 905 outputs the symbols a k ,i through a k , 4 as output 
symbols a' k ,i through a' k , 4 . 

Error signals e k ,i through e k , 4 are calculated in 
adders 902-1 through 902-4, respectively, by, in each 
of the transport channels, taking the difference 

2 0 between the output symbol of slicers 901-1 through 9 01- 
4, a k ,i through a k<4 , respectively, and the corresponding 
one of the input signals, a"' ki i through a"' k , 4 , 
respectively : 

e kJ =a'" -a k i , i = l, 2 , 3 or 4 . (14) 

25 The error signals at each of slicers 901-1 through 901- 
4 are input to error analysis 904. Error analysis 904 
determines which of the symbols a k ,i through a k , 4 is 
associated with the largest error signal e k ,i through 
e k , 4 , respectively, and the sign of the largest error. 

30 Error analysis 904 outputs an identifier of the symbol 
having the largest absolute error, W, and the sign of 
that error, SGN, to final decoder 905. If the parity 
signal indicates odd parity, the erroneous symbol is 
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most likely to be the one with the largest error, 
indicated by identifier W. Final decoder 905, then, 
adjusts the symbol having the largest error up or down 
the symbol alphabet by one symbol depending on the sign 
5 SGN (in this example, up if the sign is positive and 

down if the sign is negative) and outputs the resulting 
4-D output symbol defined by a' k ,i through a k<4 . 

The combination of N-D trellis code encoding with 
a DFE architecture requires a DFE on all four wires for 

10 each state within the trellis (see, e.g., Figure 3). 
The DFE output at a particular state is used for 
parallel branch decisions and branch metric computation 
for the branches leaving that state. The equalization 
in this situation uses a process called "per survivor 

15 processing", described more fully in Riccardo Raheli, 
Andreas Polydoros, Ching-Kai Tzou, "Per-Survivor 
Processing: A General Approach to MLSE in Uncertain 
Environments," IEEE Trans. Commun., Vol. 43, No. 2/3/4, 
pp. 354-364, February/ March/April 1995, incorporated by 

2 0 reference in its entirety, to determine the feedback 
symbols . 

The multiple decision feedback equalizers in the 
trellis decoder helps to minimize the effects of error 
propagation. However, a DFE architecture suffers from 

25 the disadvantage that it does not utilize the sample 

power contained in the intersymbol interference caused 
by the dispersion in the channel. More particularly, 
information about a 1-D symbol being transmitted during 
a time period k is contained in future received 1-D 

30 symbols from that channel and DFE does not utilize this 
signal power in deciding the currently received symbol. 

A third type of equalization, sequence detection, 
does not suffer the performance degradation of either a 
linear equalizer or a decision feedback equalizer. 

35 However, a typical sequence detector produces hard 

outputs that can severely limit the performance of an 
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error correction code. According to the present 
invention, a soft -output sequence detector is provided. 

As an example, Figure 10 shows a portion of a 4-D 
receiver utilizing sequence detection according to the 
present invention. The receiver shown in Figure 10 
includes sequence detectors 1001-1 through 1001-4, one 
for each of the four transmission channels 
corresponding to wires 103-1 through 103-4. One 
skilled in the art will recognize that a receiver can 
include any number N of transmission channels, each of 
the transmission channels providing signals to one of N 
detectors. Some or all of the N detectors can be 
sequence detectors . 

The output samples from sequence detectors 1001-1 
through 1001-4, a k ,i through a k , 4 , respectively, along 
with the second best output samples, a2 k ,i through a2 k , 4 , 
and the errors A x through A 4 are input to decoder 1002. 
Decoder 1002 decides on the receiver output samples, 
a' k ,i through a' k , 4 , based on, for example, the parity 
coding scheme or the N-D lattice coding scheme. One 
skilled in the art will recognize that the decision of 
decoder 1002 can be based on any coding scheme that can 
correct errors in one clock cycle. Feedback is 
provided to sequence detectors 1001-1 through 10 01-4 so 
that future sequences are decided using the results of 
the N-D decisions. 

Figure 11A shows a block diagram of a sequence 
detector 1100 for the PAM-5 symbol alphabet, {a}={+2, 
+1, 0, -1, -2}, where the intersymbol interference 
includes the effects of only one other symbol, i.e., 
the ISI length 5 is one (1) . In general, sequence 
detector 110 0 can utilize any alphabet and any number 
of ISI symbols (A>2 and 8>1) . Detector 1100 includes a 
Branch Metric Generator 1101, an Add- Compare -Select 
(ACS) unit 1102, Traceback Circuitry 1103, a Last-In- 
First-Out (LIFO) buffer 1104, and a starting point 



612675 v3 



determiner 1105. Sequence detectors are discussed in 
U.S. Patent Application No. 08/974,459, "Detection for 
Digital Communication Receivers," to Sreen Raghavan, 
which has been previously incorporated by reference in 
this application. 

The ISI addressed by the embodiment of detector 
1100 shown in Figure 11 is caused by just one 
previously transmitted symbol. Thus, the input sample 
to sequence detectors 1100 is given by 

r k,w = a k,w + a i a k-l,w + K,w ' ^ 15 ^ 

where, ai, w is the equalizer ISI coefficient, h k , w is the 
noise component of the output signal from the linear 
filter over wire w and a k , w is the transmitted symbol 
over wire w received in time period k. The sequence 
detector estimates the transmitted data sequence {a k , w } 
from the sequence of received samples {r kjW } . 

The state of detector 1100, S k)W , is defined as the 
past data symbol estimates. In general, a system with 
a symbol alphabet having A symbols and which suffers 
intersymbol interference from 5 previous symbols will 
have A 8 possible states. Each state corresponds to a 
possible transition path through the 5 previous 
symbols. For example, a system using a symbol alphabet 
with two symbols, {a} = {+1, -l}, and suffering ISI 
from two past symbols, 5=2, will have four possible 
sequence states of the system: symbol +1 at time k-2 
and symbol +1 at time k-1; symbol +1 at time k-2 and 
symbol -1 at time k-1; symbol -1 at time k-2 and symbol 
+1 at time k-1; and symbol -1 at time k-2 and symbol -1 
at time k-1. Sequence detector 1100 for the example 
embodiment shown in Figure 11A, a PAM-5 symbol alphabet 
with ISI resulting from one symbol, has five states -- 
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+2, +1, 0, -1, and -2 -- corresponding to the five 
symbols in the PAM-5 alphabet {a} . 

A trellis diagram depicting a state transition 
from time (k-1) to time k for sequence detector 1100 is 
5 shown in Figure 12 . A trellis diagram provides a 
graphical mechanism for predicting what the signal 
output would be for the channel in transitions from one 
state in time k-1 to another state at time k. As an 
example, from Equation 15 above, and neglecting noise, 
10 a transition from state +2 at time k-1 to a state +1 at 
time k results in a signal input to sequence detector 
1100 of 1+208,1. 

In sequence detector 1100 shown in Figure 11A, a 
branch metric generator 1101 generates distance metrics 
15 corresponding to the branches illustrated in the 

trellis diagram of Figure 12. The distance metrics 
represent the difference between the input signal to 
branch metric generator 1101, r k , w , and the calculated 
signal that is expected to be observed in each of the 
20 allowed transitions of a trellis diagram. In general, 
if there are A 5 states of sequence detector 1100 then 
there are A 5+1 branch metrics to calculate. In some 
embodiments, however, not all branches are allowed and 
therefore the number of branch metrics is reduced. 
25 For PAM-5 signaling suffering from one ISI symbol, 

there are twenty five (25) distance metrics M k , w . The 
twenty five (2 5) distance metrics generated by branch 
metric generator 1101 for the case where ISI is the 
result of one past symbol and neglecting random noise 
30 (i.e. A=5, 8=1 and f w (z) = l+^iz" 1 ) are given by: 

M k/W (0) = [r k , w -(-2-2a w ,i)] 2 ; M k , w ( 13 ) = [r k , w -(a W;1 )] 2 ; 

M k , w (l) = [r k(W - (-2-Ow,!)] 2 ; M k , w (14) = [r k , w - (2a W/1 ) ] 2 ; 

M k;W (2) = [r k , w - (-2) ] 2 ; M k(W <15) = [r k , w - (l-2a w , x ) ] 2 ; 

35 M k/W (3) = [r k , w - (-2+a W;1 ) ] 2 ; M k , w (16) = [r k . w - (l-a w .i) ] 2 ; 

M k/W (4) = [r k , w - (-2 + 2a Wi i) ] 2 ; M k , w (17) = [r k>w -l] 2 ; 
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M k , w (5) = 


[r k , w - ( 


-l-2cc W(1 ) ] 2 ; 


M k , w (18) 


= [r k , w - 


(l+a w ,i) ] 2 ; 


M k , w (6) - 


[r k , w - ( 


-l-a w ,i) ] 2 ; 


M k/W (19) 


= [r k , w - 


<l+2a Wil ) ] 2 j 


M k , w (7) = 


[r k , w - ( 


-l)] 2 ; 


M k , w (20) 


= [r k , w - 


(2-2a w ,i)] 2 ; 


M k , w (8) = 


[r k , w - ( 


-l+a w ,i) ] 2 ; 


M k , w (21) 


= [r k , w - 


(2-Ow,!) ] 2 ; 


M k , w (9) = 


[r k , w -( 


-l+2a w ,i)] 2 ; 


M k , w (22) 


= [r k , w - 


2] 2 ; 


M k , w (10) 


= [r k , w - 


(-2a W(1 )] 2 ; 


M k/W (23) 


= [r k , w - 


• (2+Ow.i) ] 2 ; 


M krW (ll) 


= [r k , w - 


(-a w ,i) ] 2 ; 


M k , w (24) 


= [r k/W - 


- (2+2a w ,i) ] 2 


M k , w (12) 


= [r k , w ] 


2 









(16) 



10 Other metrics which represent the difference 

between the input symbol and the predicted input 
symbols, assuming each of the possible state 
transitions, may be used as distance metrics. In 
general, there will be a distance metric for every 

15 transition from any state S' at time k-1 to state S at 
time k, A 5+1 for a metrics system with A symbols and S 
interfering symbols if all transitions are allowed. 
PAM-5 symboling is shown here only as an example and 
embodiments of detector 1100 can utilize other symbol 

20 alphabets and more ISI symbols. 

Add-compare-select (ACS) circuit 1102 in Figure 
11A updates a state metric for each possible state of 
the system, denoted by p k ,„(+2), p k/W (+l), p k , w ( + 0), 
Pk,w(-D, and p k ,„(-2) in the PAM-5 example, at each time 

2 5 step k. For the PAM-5 symbol alphabet the state 
metrics are given by: 

p k ,w(i) = min j={ . 2/ -i,o,i,2}{pk-i,w(j) +M k , w ( (j+2) +5 (i+2) } ; 
for i={2, 1,0, -1,-2}. (17) 

30 

In general, the state metrics represent the 
accumulated distance metrics of past states along 
transition paths that minimize the accumulated distance 
metric. Therefore, the transition metric for state S 
35 at time period k, p k , w (S), is the accumulated distance 
metric for previous states along a transition path 
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which ends at state S at time period k, state S being 
one of the possible states of the system. At time k-l, 
the state of the system may be at any state S' in the 
group of possible states of the system. Therefore, 
5 Pk, w (S) is the minimum one of Pk-i, w (S') plus the distance 
metric for transition from S' to S. A mathematical 
proof that this technique results in the least 
detection error is given in the Appendix of "Improved 
Detection for Digital Communication Receivers," U.S. 

10 Application No. 08/974,450. 

In the example of Figure 11A, the comparison 
results, D k , w (+2), D k/W ( + 1), D k , w (0), D k , w (-1) and D k , w (-2) , 
are stored in a memory of traceback circuit 1103 for 
each of the five states. The comparison results 

15 indicate the state at time period k-l which results in 
the state metric p k/W (S) for state S at time period k. 
In the PAM-5, 6=1 example shown in Figure 11A, the ACS 
results for each of the five states are given by 

20 D k , w (i)=j if p k , w (i) = Pk-i,w(j)+M k . w ((j+2)+5(i+2) ) ; 

for i={2, 1, 0, -1, -2} ; j={2, 1, 0, -1, -2} . (18) 

In general, D k , w (S) points toward the state S' at time 
k-l from which results the lowest state metric for 

2 5 arriving at state S at time k. 

When it is time for decoding, traceback circuit 
1103 traces back from a starting state, and fetches the 
data from memory in traceback circuit 1103. 

In one example of a traceback, if the traceback 

3 0 depth is 2*TB, then it is expected that a traceback of 

TB is performed every TB/2 sample times and traceback 
circuit 1106 outputs TB/2 data symbols. With little 
loss of generality, TB can be an even integer such as 
6, 8 or 16. A greater traceback depth will result in 
3 5 less error in determining the final sequence of 

symbols. Greater traceback depths, however, incur an 
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implementation cost of requiring more memory in 

traceback circuit 1103. 

During the traceback procedure, a starting state 

determiner 1105 picks the starting state, which can be 
5 based on the state metrics P k , w (s) . Traceback circuit 

1105 follows the sequence back through the comparison 

results stored in memory in traceback circuit 1103 . 

The earliest TB/2 symbols, which result in the earliest 

states, are written into last-in-first-out (LIFO) 
10 buffer 1104. The new comparison results are stored in 

the memory locations previously occupied by the 

outputted results . 

Traceback circuit 1103 determines the optimum 

sequence of symbols based on the state metrics 
15 P k , w (s) stored in starting state determiner 1105. 

Starting state determiner 1105 initializes the 

traceback procedure by setting a starting sequence. 

LIFO 1104 simply time-reverses the data coming out 

of traceback circuit 1103 because the traceback is 
2 0 performed from the current time to previous times. 



Sequence Detection with Pre-Equalization 

25 

When the channel ISI length 5 is large, or if the 
transmitted symbol alphabet size A is large, the above 
method of full sequence estimation becomes impractical 
at high symbol rates. Full sequence estimations 

3 0 require the implementation of A 5 states in the detector. 
Accordingly, an equalizer 1110 can provide pre- 
equalization by preprocessing the input samples y k ,w in- 
order to reduce the number of ISI symbols to be 
processed by sequence detector 1100. Equalizer 1110 

35 can be any equalizer that reduces the number of ISI 

symbols. Again, for purposes of example, assume that 



-38- 



612S75 v3 



the channel input alphabet size is A=5, i.e. {a}={+2, 
+1, 0, -1, -2}, and that the reduced ISI length (as 
seen by the sequence detector) is S'=l. As before, the 
technique is applicable to larger alphabets and may 
5 accommodate more than one interfering symbol in the 
reduced length. 

The output of the equalizer 1110 with A=5 and §'=l 
is, as previously described, given by 

10 r kfW =a k#w +a w< i*a k -i, w +h k , Wf (19) 

where a Wil is the equalized ISI coefficient and h k is the 
noise component of the output of the linear equalizer 
1110. The transfer function (in Z-transform notation, 
15 See A. V. Oppenheim and R.W. Schafer, Discrete-Time Signal 

Processing, (1989) ) for equalizer 1110 is, then, given by 

E w (z) = (l+aw^z- 1 ) /f w (z) . (20) 

2 0 The coefficient a w<x is chosen to minimize the noise 
variance at the output of the equalizer. Equalizer 
1110, therefore, is a reduced sequence equalizer 
because it reduces the ISI length from 8 to 8 . The 
reduced ISI length 8' is one (1) in this example. 

25 In one embodiment, reduced sequence equalizer 1110 

is implemented adapt ively. One architecture used for 
adaptive implementation is shown in Figure 11B. In 
this embodiment, equalizer 1110 includes a linear 
equalizer 1120 implementing a transfer function C(Z) = 

30 l/f (Z) = C 0 + Ci Z' 1 + . . . + C 8 Z~ 8 , adaptively followed 
by a filter 1121 implementing the function (l+a^iZ -1 + . 
. . +oc w ,8'Z" 5 ) . By implementing both equalizer 1120 and 
filter 1121 adaptively, optimal performance can be 
achieved for any cable length. Linear equalizer 1120 

35 can be adaptively implemented by using the least mean 
squares (LMS) algorithm (See E.A. Lee and D.G. 
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Messerchmitt , Digital Communications (1988) ) and a finite 
impulse response filter as shown in Figure 6. 

The coefficients a w , x through a w ,§< can be chosen 
adapt ively in the sequence detector by observing the 
5 frequency response of linear equalizer 1120. From 

linear equalizer 1120, the channel frequency response 
is deduced and a w ,i through a W/ 8- can be selected from a 
look-up table. In one embodiment with 5'=1, two 
possible values of oc W/ i (0 and 1/2) are used. One of 
10 the two possible coefficients is chosen for a w ,i by 
observing the two largest equalizer coefficients of 
linear equalizer 1120, C 0 and Ci. For example, in one 
embodiments if Ci/C 0 < -0.5 then a w , i = 0.5, otherwise 
a w ,i = 0. 

15 The benefits of combining linear equalization with 

sequence detection include (a) reduced complexity in 
the sequence detector, especially for large ISI 
lengths, and (b) reduced noise enhancement in the 
linear equalization. 

2 0 In the example described in Figure 11 with 8'=1, 

the number of states in the sequence estimator is 
reduced from 5 s to 5 . The reduced state sequence 
estimator can be implemented using the Viterbi 
algorithm. 

25 

Sequence Detection with Pre-equalization and Decision 
Feedback 

Figure 13 shows a receiver 13 50 that includes an 

3 0 embodiment of a sequence detector 13 00 having decision- 

feedback. In this embodiment, equalizer 1301, which as 
before can be any equalizer structure, pre -equalizes 
transmission channel 104 -w to a pre-determined ISI 
polynomial G w (z) of length r|<S, where 8 is the ISI 
35 length of the frequency response f w (Z) of transmission 
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channel 104-w. In the example of Figure 11, r\ is 2 and 
the I SI polynomial G w (z) is given by 

G w (z) = 1 + a Wil z _1 + a w , 2 z~ 2 . (21) 

5 

The transfer function of equalizer 13 01 is given by 

E w (z) = Gw(z)/f w (z) . (22) 

10 Sequence detector 13 00 includes branch metric 

generator 13 02, add compare select 13 03, traceback 
1304, LIFO 1305 and starting point determiner 1306. In 
general, the detection technique implemented in 
sequence estimator 13 00 may be used for any combination 

15 of 8 and t[ such that r\<5. Although the technique may be 
implemented with any sized alphabet, the example shown 
in Figure 13 is for the PAM-5, (A=5) , alphabet. The 
coefficients, a Wji and a W/2 , can be chosen adaptively to 
optimize performance of the receiver 1350. 

2 0 To perform the sequence estimation using the 

Viterbi algorithm, as outlined above, sequence detector 
1300 is still implemented with twenty five states (if 
the data symbols are PAM-5 values) . The branch metric 
computations from a trellis diagram now accounts for 

25 the intersymbol interference due to the symbols 

transmitted two sample times before as well as the 
symbol transmitted during the last period. In one 
embodiment, the branch metrics computed by branch 
metric generator 13 02 with decision feedback are given 

30 by: 



M k , w (0) = [r k(W -a w , 2 D k . 1 (-2) - (-2-2a W/1 )] 2 
M k , w (l) = [r k/W -a w , 2 D k _ 1 (-l) - (-2-a Wjl ) ] 2 ,- 
M k , w (2) = [r kjW -a w , 2 D k _ x (0) - (-2) ] 2 ; 
35 M k , w (3) = [r k , w -a w , 2 D k _ 1 (l) - (-2+a W;1 ) ] 2 ; 

M k , w (4) = [r k/W -a w , 2 D k . 1 (2) - (-2+2a w ,!)] 2 ; 
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M k , w 


(5) = 


L-^KjW VA 'W / 2- L - / K-l 


(-2) - 


(-1-2CC,, i ) 1 2 




M k , w 


(6) = 


[r k w _ o^ w 2Dk-i 


(-1) - 


(-l-Ow.i) ] 2 ; 




M k , w 


(7) = 


[ r k, w~OC w< 2Dk-l 


(0) - ( 


- 1 ) ] 2 ; 




M k , w 


(8) = 


t r k w -oc w 2Dk-l 


(1) - ( 


-l+a w ,i) ] 2 ; 


5 


M k(W 


(9) = 


[^k w -ot w 2D k -l 


(2) - ( 


-l+2a w ,i) ] 2 ; 




Mk,w 


(10) 




i (-2) 


- (-2a„,i) ] 2 ; 




M kjW 


(11) 


LJ-k,^? ^w, 2 x -' k 


i (-1) 


- (-a w i) ] 2 ; 




M kjW 


12) 


= Trv ..-fx., iDv 

L J -k,W ^W, A^K 


i (0) ] 


2 . 




M k w 


13 ) 


= t^k, w - <^w, 2^k 


-i (1) - 


a -, 1 2 ■ 


10 


f/[ k w 


14 ) 


= [ r k,w -a w y 2Dk 


* (O) - 






]V[ k w 


15) 


= [^^"O^w^Dk- 


i \ ^ ) 


- l~i -On \ 1 2 




Mk w 


16) 


= [ ^~k, w _ CXw, 2-Dk- 


i ( - 1 ) 


\ 1 <JC W , 1 / J / 




jyj k w 


17 ) 


= t^"k, w -a w, 2D k - 


1 \ u / 






]V[ k w 


18 ) 


= [l*k,w~0tw,2Dk- 


1 V J- ^ 


( 1+Ct w i) ] 2 ; 


15 


jy[ k 


19) 


= [ r k,w~Ctw,2Dk- 


i \<£ ; - 


( 1 _i_ Orv n 2 . 




M k , w 


20) 


= [r k/W -a w , 2 D k _ 


i(-2) 


- (2-2a Wrl ) ] 2 




M k ,w 


21) 


= [r k , w -a W/2 D k . 


i(-D 


- (2-a W/1 ) ] 2 ; 




M k , w 


22) 


= [r k , w -a w , 2 D k _ 


i(0) - 


2] 2 ; 




M k , w 


23) 


= [r k , w -a w , 2 D k . 


i(D - 


(2+a W/1 ) ] 2 ; 


20 


M k , w 


24) 


= [r k , w -a w , 2 D k - 


i(2) - 


(2+2a w , x ) ] 2 . 



The ISI due to the transmitted symbol at time (k- 
2) is removed from the received sample r k , w before the 

2 5 branch metric of the sequence detector that accounts 

for the ISI due to the transmitted symbol at time (k-1) 
is computed. After this calculation, the previously 
described calculation is performed to remove the ISI 
due to the (k-l)th transmitted symbol. 
30 Add compare select (ACS) 1303 then computes the 

state metrics p k , w (j) and the comparison results D k>w (j) 
as described above in equations 16 and 17, 
respectively. Traceback 1304 accepts a starting point 
from starting point determiner 13 06, as described 

3 5 above, and outputs a set of decided on symbols to LIFO 
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1305. LIFO 1305, then, outputs the resulting symbols 
in reverse chronological order from that received. 

Sequence detection in combination with error correction 

5 

Although achieving excellent noise margins, the 
combination of sequence detection with error correction 
codes is problematic. Sequence detectors usually 
produce hard decisions (i.e., decisions that do not 

10 contain information on reliability) , which become input 
signals to error correcting codes. Most error 
correcting techniques, such as the parity coding or 4-D 
lattice coding proposed for Gigabit Ethernet, rely on 
soft decisions (i.e., decisions that contain 

15 reliability information) to achieve full performance. 
See, e.g., S. Lin and D . J. Costello, Jr., Error Control 
Coding: Fundamentals and Applications (1983) . Thus, a typical 
sequence detector in combination with a decoder using 
an error correcting code does not achieve the improved 

2 0 SNR margins of both the sequence detector and the error 

correcting code unless the decoder is provided with a 
soft decision from the sequence detector. 

Figure 14 shows a sequence detector 1400-w 
according to the present invention. Sequence detector 
25 1400-w is coupled to receive signal r k;W from wire w. 
Sequence detector 14 0 0-w includes branch metric 
generator 14 02-w, add compare select (ACS) 1403 -w, and 
starting point determiner 14 06-w. Add compare select 
1402-w and starting point determiner 1406-w are each 

3 0 coupled to traceback 14 04. 

Traceback 1404 is coupled to each wire w so that 
the traceback can be accomplished on N-D symbols rather 
than performing a separate traceback on N 1-D symbols, 
where N is the number of wires. Traceback 1404 is also 
35 coupled with LIFO 1405. LIFO 1405 outputs the final 
symbol stream a' k , w for each wire w. 
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Although a sequence detector according to the 
present invention can accommodate any symbol alphabet 
and any number of I SI symbols, for example sequence 
detector 1400 shown in Figure 14 is for a PAM-5 
5 alphabet where input signals suffer the influence of 
one past ISI symbol (i.e., the ISI length is 1). 
Equalizer 1401-w, as has been previously discussed, 
executes a transfer function E (Z) = ( l+a w ,iZ _1 ) /f w (Z) 

and therefore sequence detector 1400-w detects a signal 

10 that includes ISI from one past symbol. Branch metric 
generator 14 02 -w, therefore generates the branch 
metrics as described in Equation 16. 

Add compare select (ACS) 14 03-w computes the state 
metrics p k , w (i) ( i = -2 , -1 , 0 , 1 , 2 ) according to Equation 17 

15 and the ACS results D k;W (i) according to Equation 18. 
Additionally, ACS 1403-w computes a second best state 
metric p2 k , w (i), a second ACS result D2 k/W (i), and a 
difference result A k , w (i) . The second best state metric 
can be computed according to the equation 

20 p2 kw (i) = second minimum (p k -i, w (j) + M k , w (5 (i+2 ) + ( j +2 ) ) ) ; 

j={-2, -1, 0, 1, 2}, (24) 

where i={-2, -1, 0, 12}. The second ACS result can be 
computed according to 

D2 k>w (i) = j if P 2 k>w (i) = Pk _ Kw U) + M Kw {5{i + 2) + U +2)), (25) 

25 where i = { -2 , - 1 , 0 , 1 , 2 } and j= (-2, -1, 0, 1,2} . Finally, 
the difference result can be computed according to 

A*, w (0 = p2 ktW (i)-p ktW (i) ■ (26) 
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Traceback 14 04 receives the ACS results, the second ACS 
results, and the difference results from each state on 
each wire as well as a starting point signal from 
starting point determiner 1406-w for each wire w. 
5 Figure 15 shows an embodiment of a 4-D traceback 

1404 in combination with a series of sequence detectors 
14 0 0-w. It is understood that, in general, for an N- 
wire configuration, traceback 1404 coupled into N 
sequence detectors similar to that shown in Figure 14, 

10 one for each wire w. In Figure 15, traceback 1404 
includes a parity code decoder 1504 although other 
coding schemes can be used, provided that the coding 
scheme can correct symbols within one clock cycle. 

For exemplary purposes, Figure 15 shows a four- 

15 wire parity-code decoder. Traceback 1404 includes a 

read module 1501-1 through 1501-4, one for each of the 
four wires. Read module 1501-1 through 1501-4 receives 
parameters T k/W from add compare select 14 03-w and 
starting point determiner 1406-w (Figure 14) . 

20 Parameters I\, w includes the add compare results D k<w (i) , 
D2 k/W (i) and A k;W (i), where i=(-2, -1, 0, 1, 2) for PAM-5 
signaling, as well as a starting point SP k , w for each 
wire w. As was discussed before, starting point 
determiner 1406-w chooses a starting point SP kiW , which 

25 can be based on the state metrics p k/W (i) , for traceback 
1404 . 

Traceback 14 04 in Figure 15 traces back to arrive 
at the best sequence a k/W for wire w. For each clock 
cycle k, read module 1501-w arrives at a best symbol 

3 0 a k , w , a second best symbol a2 k/W and an associated 
reliability s k , w for each wire w. 

As described above, the 4-D parity coding scheme 
only transmits 4-D symbols having even parity. A 
single error in one 1-D symbol will cause the parity of 

35 the 4-D symbol to become odd. Similar to "4-D 

slicing", traceback 1404 recognizes the parity error 
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and makes corrections to the 4 1-D symbols from read 
modules 1501-1 through 1501-4 for clock cycle k based 
on the reliability of each of the 1-D symbols. 

Hagenauer has shown that, within a Viterbi 
5 decoder, the reliability of decision symbol paths 

merging at each state grows with the difference between 
the state metrics between the two paths. See J. 
Hagenauer and P. Hocher, "A Viterbi Algorithm with 
Soft-Decision Outputs and its Applications," Proc. 

10 GLOBECOM *89, 1680-1686, November 1989) . Similar to 
Hageauer's Soft Output Viterbi Algorithm (SOVA) , each 
of read modules 1501-1 through 1501-4 outputs the 
difference metric, i.e. the reliability measure, 
between the best two paths entering each state, 8 k ,i 

15 through s k , 4 , respectively. SOVA uses these metrics 
over a range of sample times within the trellis to 
output soft decisions for every symbol. 

However, 4-D parity traceback 14 04 can recognize 
when a single error occurs. Therefore, only the 

20 difference metrics at the time of the error are 
required to correct errors. Because the actual 
decoding is accomplished during traceback in each of 
sequence detectors 140-1 through 140-4, traceback 1404 
recognizes an error in its channel and corrects the 

25 error in its own sequence path. 

For each clock cycle k, traceback 1404 retrieves 
each of the first choice 1-D symbols a k/1 through a k(4 , 
the second choice 1-D symbols a2 kii through a2 k<4 , and 
the reliability measures s k ,i through £ k , 4 , and determines 

30 the finally decided 4 1-D symbols a' k ,i through a' k<4 . 

For each clock cycle k, parity check 1502 receives 
the first choice symbols a k/i through a k , 4 from read 
modules 1501-1 through 1501-4, respectively, determines 
the parity of the resulting 4-D symbol and outputs a 

35 parity signal indicating the parity of the 4-D symbol. 
Error analysis 1503 receives reliability measures s k ,i 



-46- 



S12675 v3 



through s k/4 from read modules 1501-1 through 1501-4, 
respectively, determines which of the sequence 
detectors w has the least reliability, indicating which 
result is most likely to be incorrect, and outputs a 
5 wire signal W indicating which symbol is most likely to 
be incorrect. Decoder 1504 receives the first choice 
symbols a krl through a k , 4 , the second choice symbols a2 k ,i 
through a2 k , 4 , the parity signal from parity check 1502, 
and the wire signal from error analysis 1503 . 

10 If the parity signal indicates that the parity of 

the first choice 4-D symbol is even, then the first 
choice symbols a k<1 through a k)4 are output as the 
finally decided symbols a' k ,i through a' k(4 . However, an 
odd parity indicates an error in one of the first 

15 choice symbols a k ,i through a kj4 . If the parity signal 
indicates an odd parity, the symbol indicated by the 
wire signal W is replaced by a corresponding one of 
second choice symbols a2 k ,i through a2 k , 4 and the 
resulting 4-D symbol is output as finally decided 

20 symbols a' k ,i through a' k , 4 . 

Additionally, decoder 1504 informs read modules 
1501-1 through 1501-4 of the finally decided symbols 
a' k ,i through a' k , 4 b Y indicating, for each of read 
modules 1501-1 through 1501-4, which of the first 

2 5 choice symbols or the second choice symbols was output 
as the finally decided symbols for clock cycle k. Read 
modules 1501-1 through 1501-4 can then traceback 
accordingly and output the first choice symbols, second 
choice symbols, and reliability measures for clock 

30 cycle k-1 (i.e., a k -i,i through a k _i /4 , a2 k _i ( i through a2 k . 
i, 4 , and s k _i ( i through s k _i >4 , respectively) . 

In other words, read module 1501-w outputs the 
best possible step back a k , w , the second best step back 
a2 k/W , and the reliability measure s k<w for each wire for 

35 clock cycle k. Parity check 1502 performs a parity 
check on the best possible step back a k , w . Error 
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analysis 1503 determines the wire most likely to be 
incorrect. If the parity passes, decoder 1504 outputs 
the best possible step back a k , w for clock cycle k. If 
parity fails, then decoder 1504 replaces one of the 
5 best possible symbols with the associated second best 
symbol, based on which wire is most likely to be 
incorrect, and outputs the resulting 4-D symbol. The 
choice of best symbol or second best symbol for each 
wire w is communicated back to read module 1501-w so 
10 that read module 15 01-w can use the appropriate symbol 
to step back to clock cycle k-1. The replacement 
choice, then, affects only one read module. Therefore, 
the next set of symbols will be affected in one read 
module only. 

15 As shown in Figure 14, the output symbols a' k , w are 

output to LIFO 1405, which time reverses the order of 
the symbol stream and outputs the resulting symbol 
stream a' k;W . 

One skilled in the art will recognize that in 
2 0 general a sequence detector according to this invention 
can accommodate any symbol alphabet and the effects of 
any number of ISI symbols. Additionally, the sequence 
detector may include decision feedback as shown in 
Figure 13. 

25 



Reduced Complexity Sequence Detection Using State 
Reduction 

30 

If the alphabet size is large or if the ISI length 
at the sequence detector is large then sequence 
detector 14 0 0-w shown in Figure 14 and traceback 14 04 
3 5 using parity coding shown in Figure 15 become 

impractical at high symbol rates. The number of states 
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required in read modules 1501-1 through 1501-4 is A* 1 on 
each wire, where A represents the number of symbols in 
alphabet {a} and r| represents the ISI symbol length at 
the sequence detector (i.e. at the input terminal of 
5 sequence detector 1400 in Figure 14) . With a PAM-5 
alphabet and r\=2 ISI symbols, each of read modules 
1501-1 through 1501-4 requires twenty five (25) states 
in order to perform sequence detection. A decoder 
utilizing a large number of states is expensive, 

10 difficult to implement, and consumes a lot of power. 

Figure 16 shows a sequence detector 1600 -w having 
reduced complexity sequence detection. In particular, 
sequence detector 1600-w includes branch metric 
generator 1602 -w, add- compare -select 1603 -w, and 

15 starting point determiner 1605 -w. Traceback 1604 and 
LIFO 1606 are coupled into sequence detector 1600-2 as 
well as similar detectors coupled to the remaining N 
wires. As an example, sequence detector 1600-w is 
shown for the PAM-5 alphabet, although embodiments of 

20 sequence detector 1600-w can utilize other symbol 
alphabets as well. 

The PAM-5 symbol alphabet can be segregated into 
two families, an odd family X having the PAM-5 symbols 
{-1, +1} and an even family Y having the PAM-5 symbols 

25 {-2, 0, +2}. A detector state can now be defined as 
the previous n families X or Y, as opposed to the 
previous r| PAM-5 symbols {-2, -1, 0, +1, +2}. 
Therefore, the number of states required for the PAM-5 
symbol alphabet with n=2 ISI symbols is reduced from 2 5 

3 0 states to 4 states on each transmission channel w=l 

through L. For a four wire system (4-D decoding, for 
example) , there are a total of sixteen (16) states 
instead of one hundred (100) states. 

Reduced state detection can be accomplished when 

35 the minimum squared distance between any two parallel 

branches of a state transition S— »S' exceeds the minimum 
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squared distance between any two paths in the trellis. 
A parallel branch refers to transitions S->-S' between 
individual states through different symbols. For 
example, a state S = X can transition to a state S' = X 
5 through receipt of either a -1 symbol or a +1 symbol. 
The actual squared minimum distance between 
sequences does not decrease and thus the performance 
suffers little or no degradation from that of full 
state sequence detection. Gigabit Ethernet using a 

10 PAM-5 symbol set suffering ISI from two (2) symbols 
meets this criteria. 

Figure 17 shows a trellis diagram displaying the 
reduced state transitions and all parallel PAM-5 
transitions. In Figure 17, a state is represented by 

15 two consecutive symbols (reflecting an ISI length of 

2) . A transition from state S at time k-1 to state S' 
at time k has two or three parallel branches, depending 
upon whether the new symbol entering at state S' is in 
family X or family Y. For example, a transition from 

20 state XX at time k-1 to state XX at state k has two 

branches because the incoming symbol must be either a - 
1 or +1 PAM-5 symbol. A transition from state XX at 
time k-1 to a state XY at time k, however, indicates 
that either a -2, 0 or +2 symbol is received and 

2 5 therefore there are three branches. 

In Figure 16, equalizer 1601-w can execute the 
transfer function 

E(Z) = (l+axZ^+asZ' 2 ) /f (z) . (27) 

30 

Therefore, the expected signal input to decoder system 
1600 is 

r k , w =a k , w +aia k -i (W +a 2 a k -2,w. (27) 



35 



612S75 v3 



Branch metric generator 1602 -w computes the branch 
metrics for the state transitions displayed in Figure 
17. In the reduced state trellis shown in Figure 17, 
branch metric 1602 -w first decides on which of the two 
5 or three branches of the transition from state S to 
state S' to assign to the state transition S-»s' . The 
decision of which branch performs the S— »s' transition 
is based on calculating a distance metric for each 
branch and choosing the branch having the lowest 

10 metric. For example, in the transition from state S=XX 
to state S'=XX branch metric generator first determines 
which of the two branches (-1 or +1) are traversed 
before calculating the metric. The decision of which 
branch is traversed is stored in branch decision 

15 B kjW (S— »S' ) . The branch decision and the metric are both 
communicated to ACS 1603 -w. 

For each state S at k-1, symbols a k _i(S)and a k _ 2 (S) 
are known based upon feedback from ACS 1603 -w to Branch 
Metric Generator 1602 -W, as is shown in Figure 16. For 

20 each state transition S — » S', branch metric generator 
takes the difference between the input signal and the 
ISI portion of Equation 27 to obtain a difference 

ct(S-»S') = r k , w - a x a k -i, w (S) - a 2 a k _ 2 , w (S). (28) 

25 

The difference a is then compared with the symbols for 
each possible branch of the state transition S to S' . 
The symbol chosen for the branch, a' k/W (S->S' ) , is then 
assigned to the transition from state S to state S' . 
3 0 As is shown in Figure 18 The branch metrics can be 

computed for each transition S to S' according to the 
equation : 

M k , w (S-»S') = [r k , w - a' k , w (S-»S' ) - 

35 aia k - x , w (S) - oc 2 a k - 2; w(S) ] 2 , (29) 
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where the valid transitions (S-»S' ) in Figure 18 are 
S-»S 7 = XXX, XXY, YXX, YXY, XYX, XYY, YYX and YYY. The 
notation "ABC" used above and on Figure 18 indicates an 
S->-S' transition from S=AB to S'=BC. 
5 Add-compare-select 1603 -w receives the branch 

metrics M k(W ((S->S 7 ) and branch decisions B k(W (S-»S 7 ) 
from branch metric generator 16 02 -w and calculates the 
state metrics P k/W (S 7 ) according to the equation 

10 Pk.w(S') = min j = {S } (P k -i / w(j) + M k , w (S->S 7 ) ) , (30) 

where j is equal to each S such that S— »S' is allowable. 

Add-compare-select 1603-w also determines the ACS 
results for each of the four final states S' and 
15 communicates those results to traceback circuit 1604. 
The ACS result D k , w (S') is the path resulting in state 
S' having the lowest metric M(S— >S'). Because there are 
only two allowed paths that result in state S' (see 
Figures 17 and 18) , the second best choice is 
2 0 automatically the path that is contraindicated by 
Dk,w(S') and need not be separately stored. 

The error A k , w (S') is the difference in metrics 
between the two paths resulting in state S' : 

25 A k , w (S') = |M(Si->.S' ) -M(S 2 -»S' ) I, (31) 

where S x is one of the two initial states that 
transition to the final state S' and S 2 is the other of 
the two initial states that transition to the final 

30 state S 7 . For example, from Figure 18, if S'=YX, then 
Si and S 2 are the states XY and YY, respectively. 

Finally, the branch decisions of branch metric 
generator 1602 -w are also communicated to traceback 
circuit 1604. Branch decision Bl k;W (S') corresponds to 

35 the decision on the path S^S' indicated by D k#w (S'). 

Branch decision B2 k , w (S') corresponds to the decision on 
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the path S-»S' contraindicated by D k/W (S'). Therefore, 
in the soft-decision process, if the traceback circuit 
1604 is altered to the second most likely path, the 
parallel path decision for the second most likely path 
5 is available to traceback circuit 1604. 

Traceback circuit 1604 can be the same as 
traceback 1404 of Figure 15 except that read modules 
1501-1 through 1501-4 receive a different set of 
parameters r k/W . In traceback circuit 1604, r k/W 

10 includes the ACS parameters D k , w (Si), A k , w (Si), Bl k , w (Si), 
B2 k , w (Si) , where S ± = (XX, XY, YX, YY) , and the starting 
point SP k , w from starting point determiner 1605 -w. As 
described above, read modules 1501-1 through 1501-4 
store the ACS results in memory and, starting from 

15 starting point SP k , w determined by starting point 

determiner 1605, determines the most likely symbol a k , w 
and the second most likely symbol a2 k(W for clock cycle 
k. An reliability measure indicating the difference in 
distance metrics between the most likely symbol and the 

2 0 second most likely symbol, s k , w , is also determined. 

As is shown in Figure 15, read modules 1501-1 
through 1501-4 output the parameters a k , w to parity 
check 1502 and decoder 1504, parameters a2 k , w to decoder 
1504, and parameters s k , w to error analysis 1503. As 

2 5 was previously discussed, decoder 1504 outputs a the 

best symbols a' k>w based on the parity check and informs 
read modules 1501-1 through 1501-4 of the choice. Read 
modules 1501-1 through 1501-4 then proceed to determine 
most likely and second most likely symbols for clock 

3 0 cycle k-1 until the traceback is complete. 

In sequence detector 1600 -w of Figure 16, the 
minimum squared distance between parallel branches of 
any transition S-»S' should be at least twice as large 
as the minimum squared distance of the overall decoder. 
3 5 Because there is no protection between parallel branch 
decisions S -> S" of sequence detector 1600-w, this 
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requirement on minimum squared distances should hold 
true in order to prevent the overall minimum distance 
from decreasing because of reduced state detection. 

As was previously discussed, the 4-D parity code 
5 provides 3 dB of coding gain, which doubles the squared 
minimum distance between possible paths. However, this 
code provides no protection between parallel branches 
of transitions along one wire. Therefore, this overall 
requirement on minimum distances prevents the minimum 
10 squared distance from decreasing because of reduced 
state detection. This requirement holds for Gigabit 
Ethernet standards, as described above. Although the 
requirement should hold in general, it may not be held 
for all embodiments of the invention. 

15 

Simplified DFE 

Reduced sequence detection can also be 
accomplished utilizing decision feedback equalization 

2 0 (DFE) . However, a simplified DFE provides a simple and 
easy implementation for accomplishing the equalization 
process in the allotted time (8 ns in the example of 
gigabit transmission over four wires) . 

Figure 19 shows an example of a simplified 

25 decision feedback equalizer 1900. The simplified 

decision feedback equalizer includes a pre-equalizer 
section 1901, adder 1902, slicer 1903, delays 1904 and 
1905, and selector 1906. Pre-equalizer section 1901 
can be any equalizer structure that reduces the ISI 

30 length to L symbols. Pre-equalizer section 1901, 
therefore, executes the transfer function 

r(z)= i + «,z-^. + gt z-^ (32) 



-54- 



612675 v3 



where a x through a L are the multiplier coefficients of 
pre-equalizer section 1901 and f (Z) is the response of 
the input channel (see Equation 2 for the response of a 
transfer channel) . 
5 The output signal from feedforward section 1901, 

a' k , is input to adder 1902. Adder 1902 subtracts the 
signal from selector 1906, a'' k , from the output signal 
from feedforward section 1902, a' k . The resulting 
signal, a' ' ' k = a' ^-a' ' k , is input to slicer 1903. 

10 Slicer 1903 outputs a symbol a k that is closest to the 

input signal a''' k . The feedback section 1905 (see also 
feedback section 811 of Figure 8) of decision feedback 
equalizer 1900 comprises delays 1904 and 1905 and 
selector 1906. Selector 1906 receives each of L past 

15 symbols a k -i through a k _ L and uses these symbols to 

access a lookup table. The lookup table holds values £i 
through The output signal of selector 1906, a'' k , 

then is that one of 4i through that corresponds to 
the combination of inputs a k _i through a k - L . The time 

20 required to look the results up in a look-up table is 
much less than the time required to perform the L 
multiplies and L additions required of the feedback 
section shown, for example, as feedback section 811 of 
Figure 8 . 

25 In some embodiments, selector 1906 receives the 

look-up values through %q as input signals. In some 
embodiments, the look-up values ^i through %q are 
preset. The look-up values through £, Q can also be 
adaptively chosen to optimize performance of the 

30 receiver of which decision feedback equalizer 1900 is a 
part. In most embodiments, Q = A L where A is the size 
of the symbol alphabet . 

As an example, in a system using the PAM-5 
alphabet where L=2 , and Q is 2 5 there are twenty- five 

35 (25) lookup values (i.e., Q=25). Because the 
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intersymbol interference in the input signal to adder 
1902 is the result of two (2) ISI symbols, 



a k + aa k _i 



Pa k - 2 



where a and (3 are the interference parameters and n k is 
random noise. The twenty-five values for the look-up 
table, therefore, are given by: 
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The parameters a and P can be adaptively chosen 
and the table updated periodically by calculating the 
look-up values ^ through ^ Q and inputting them into 
selector 1906. When decision feedback equalizer 1900 
5 is utilized, for example, as equalizer 505-j in 

receiver 501-j of Figure 5B, look-up values ^i through 
B,q can be calculated by coefficient update 506-j and 
read into equalizer 505-j . 

Figure 2 OA shows a sequence detector 2 000. 

10 Sequence detector 2 0 00 can be any sequence detector 
system having feedback, including sequence detector 
1300 (Figure 13) and sequence detector 1600 (Figure 
16) . As before, sequence detector 2000 utilizes any 
symbol alphabet and includes trellis decoding for any 

15 number of past ISI symbols. 

Pre-equalizer section 2001 receives signal yk, w , 
and executes a transfer function, such as that shown in 
Equation 32, that removes the ISI influence from all 
but L past symbols. Feedback section 2003 outputs a 

2 0 signal a n kw that removes the influence from an 

additional M past symbols based on the inputs from the 
ACS. Sequence detector, therefore, utilize states 
describing the past L-M ISI symbols. Figure 12, for 
example, illustrates a trellis diagram for L-M = 1. 

25 Figures 17 and 18, for example, illustrate a trellis 

diagram for a reduced state sequence detector with L-M 
= 2 . 

As was described before, branch metric generator 
2004 outputs a set of branch metrics M k (S— >-S') for 

30 transitions between states S and state S' of the 

decoder. ACS 2005 outputs the ACS results to traceback 
circuitry 2006, the transition metrics to starting 
point 2007. Traceback circuit 2006 outputs the symbols 
decided by sequence detector 2000, in reverse 

35 chronological order, and LIFO 2008 reverses the order 
of those symbols to output symbol stream ak iW . 
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The output signals S k , w output ted from ACS 2 005 to 
feedback section 2 0 03 are given by the traced back 
sequence from traceback circuit 2 006. 

From Figure 20, if the past L symbols have been 
5 properly decoded than the influence of intersymbol 

interference will be completely canceled. In general, 
feedback section 2003 can be any feedback structure. 
An example feedback section is feedback section 811 
shown in Figure 8. Feedback section 811, however, 
10 includes M multipliers (multipliers 806-1 through 806- 
M) and an M- input adder (adder 8 07) for the case of M 
ISI symbol cancellation. 

One embodiment of feedback section 2003 includes 
feedback sections like feedback section 811. For 
15 Gigabit Ethernet, at symbol rates of 12 5 Mhz on each 
wire, the timing constraints of the sequence detector 
are severe. When "per-survivor processing" (see, e.g., 
sequence detector 1300 of Figure 13) is used feed-back 
section 2003 must include feedback section 811 repeated 

2 0 for each state of equalizer 2 000 because the final 

state of equalizer 2 000 is not determined until the 
latest decision of ACS 2005 (i.e., the parameters S k , w 
are determined by ACS 2 0 05) . 

Figure 2 0B shows an embodiment of feedback section 
25 2003 that includes a look-up feedback section 2100. 

Look-up feedback section 2100 outputs an output signal 
a'' k from look-up values through £, Q in response to the 
ACS parameters S k _i through S k - L . Look-up values ^i 
through £, Q can be preloaded into feedback section 2100 

3 0 or may be periodically adaptively chosen and read into 

feedback section 2100. Values for look-up values 
through ^ Q for two ISI symbols and a PAM-5 symbol 
alphabet are given above in Equation 34. 

The embodiments discussed above are exemplary only 
35 and are not intended to be limiting. One skilled in 
the art will recognize multiple variations of these 
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embodiments that are intended to be included within the 
scope of this disclosure. As such, the invention is 
limited only by the following claims. 
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CLAIMS 

We claim: 

5 1. A receiver, comprising: 

at least one one-dimensional receiver, each 
of the at least one one -dimensional receivers 
coupled to receive an input signal, at least one 
of the at least one one-dimensional receiver 

10 including a filter, analog- to-digital converter, 

and decision feedback equalizer coupled in series, 
the decision feedback equalizer including a look- 
up table in a feedback portion; 

a multi-dimensional decoder coupled to 

15 receive an output signal from each of the at least 

one one-dimensional receiver, the multi- 
dimensional decoder outputting a stream of multi- 
dimensional symbols based on the output signals 
received from the at least one one -dimensional 

2 0 receiver. 

2. The receiver of Claim 1, further including a 
coefficient update to adaptively chose equalizer 
parameters for the equalizer. 

25 

3. The receiver of Claim 1, further including an echo 
canceller circuit coupled in series with the filter, 
the analog-to-digital filter, and the equalizer. 

30 4. The receiver of Claim 1, further including a NEXT 
canceller circuit coupled in series with the filter, 
the analog- to-digital filter, and the equalizer. 



5. The receiver according to Claim 1, further 
35 including a baseline wander correction circuit coupled 
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in series with the filter, the analog- to-digital 
filter, and the equalizer. 

6. The receiver according to Claim 1, wherein the 
5 filter includes an analog equalizor. 

7. The receiver of Claim 1, further including an 
amplifier coupled in series with the filter, the 
analog-to-digital filter, and the equalizer. 

10 

8. The receiver of Claim 1, wherein the 
multidimensional decoder includes 

at least one 1-D slicer, each of the at least 
one 1-D slicers coupled to receive an equalized 

15 signal from one of the at least one one- 

dimensional receivers, the 1-D slicer estimating a 
symbol and an error signal for the associated one- 
dimensional receiver; 

an error correction circuit coupled to 

2 0 receive the error signals from each of the at 

least one 1-D slicer, the error correction 
outputting an error result indicating which of the 
at least one one-dimensional receivers is most 
likely to be incorrect; 

2 5 a parity check circuit coupled to receive the 

symbol from each of the at least one 1-D slicer, 
the parity check circuit outputting a parity 
signal indicating whether the mult i -dimensional 
symbol formed by the symbols from each of the at 

3 0 least one 1-D slicer is correct; and 

a decoder coupled to receive the parity 
signal, the error result, and the symbols from 
each of the at least one 1-D slicer and outputting 
a multidimensional symbol formed from the symbols 
3 5 from each of the at least one 1-D slicer if the 

parity signal indicates no parity error and formed 
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from the symbols from each of the at least one 1-D 
slicer corrected by modifying the symbol 
associated with the receiver indicated by the 
error result if the parity signal indicates a 
5 parity error. 

9. A receiver, comprising: 

at least one one -dimensional receiver, each 
of the at least one one -dimensional receivers 
10 coupled to receive an input signal, each of the at 

least one one -dimensional receivers including a 
filter, analog-to-digital converter, and sequence 
detector; 

a mult i -dimensional decoder coupled to 
15 receive an output signal from each of the at least 

one one-dimensional receiver, the multi- 
dimensional decoder output ting a stream of multi- 
dimensional symbols based on the output signals 
received from the at least one one -dimensional 
2 0 receiver. 

10. The receiver of Claim 9, wherein the at least one 
one -dimensional receiver further includes a pre- 
equalizer, the sequence detector being coupled to 

25 receive a pre-equalized signal from the pre-equalizer . 

11. The receiver of Claim 9, wherein the sequence 
detector includes 

a branch metric generator, the branch metric 
30 generator calculating a set of branch metrics 

based on an input signal to the branch metric 
generator; 

an add-compare-select circuit, the add- 
compare-select circuit coupled to receive the set 
35 of branch metrics from the branch metric generator 

and calculating a set of state metrics and a set 
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of ACS results based on the set of branch metrics; 
and 

a starting point determination circuit 
coupled to receive the set of state metrics and 
5 determine a starting point value based on the set 

of state metrics. 

12. The receiver of Claim 11, wherein the branch 
metric generator is coupled to receive the set of ACS 

10 results from the add- compare -select circuit and 

calculates the set of branch metrics based on the input 
signal and the set of ACS results. 

13. The receiver of Claim 11, wherein the branch 

15 metric generator is coupled through a look-up table to 
the add-compare select circuit and calculates the set 
of branch metrics based on the input signal and the set 
of ACS results . 

20 14. The receiver of Claim 11, wherein the add-compare- 
select calculates a set of second choice ACS results 
and a set of differences based on the set of branch 
metrics . 

25 15. The receiver of Claim 14, wherein the 
multidimensional decoder includes 

at least one read block, each of the at least 
one read blocks coupled to one of the at least one 
receivers to receive the set of ACS results, the 
3 0 set of second choice ACS results, the set of 

differences, and the starting point value, each of 
the at least one read block determining a first 
symbol, a second symbol, and a reliability metric ; 
a parity check block coupled to receive the 
3 5 first symbol from each of the at least one read 

block and computing a parity signal; 



-63- 



612675 v3 



an error analysis block coupled to receive 
the reliability metric from each of the at least 
one read block, the error analysis block 
generating an error indication signal indicating 
5 which of the first symbols of at least one read 

block is most likely not to be correct; 

a decoder coupled to receive the first symbol 
and the second symbol from each of the at least 
one read block, the parity symbol from the parity 
10 check block, and the reliability metric from the 

error analysis block and determining a final set 
of symbols. 

16. The receiver of Claim 15, wherein each of the at 
15 least one read block is coupled to receive a final 

result signal from the decoder, and wherein each of the 
at least one read block performs a traceback operation 
based on the set of ACS results, the set of second 
choice ACS results, the set of differences, and the 
20 final result signal. 

17. The receiver of Claim 11, wherein the sequence 
detector is a reduced complexity sequence detector with 
state reduction. 

25 

18. The receiver of Claim 9, further including a 
coefficient update to adapt ively chose equalizer 
parameters for the equalizer. 

3 0 19. The receiver of Claim 9, further including an echo 
canceller circuit coupled in series with the filter, 
the analog-to-digital filter, and the equalizer. 

20. The receiver of Claim 9, further including a NEXT 
35 canceller circuit coupled in series with the filter, 
the analog-to-digital filter, and the equalizer. 
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21. The receiver according to Claim 9, further 
including a baseline wander correction circuit coupled 
in series with the filter, the analog-to-digital 

5 filter, and the equalizer. 

22. The receiver according to Claim 9, wherein the 
filter includes an analog equalizor. 

10 23. The receiver of Claim 9, further including an 
amplifier coupled in series with the filter, the 
analog- to-digital filter, and the equalizer. 



24. A method of detecting symbols transmitted over a 
15 plurality of channels, comprising: 

receiving an input signal from each of the 
plurality of channels, - 

filtering the input signal from each of the 
plurality of channels to obtain a filtered signal 

2 0 for each of the plurality of channels; 

digitizing the filtered signal from each of 
the plurality of channels to obtain a digitized 
signal for each of the plurality of channels; 

equalizing the digitized signal with a 
25 decision feedback equalizer having a look-up table 

in at feedback loop from each of the plurality of 
channels to obtain an equalized signal from each 
of the plurality of channels; 

determining a multidimensional symbol from 

3 0 the digitized symbols from each of the plurality 

of channels. 



35 



25. The method of Claim 24, wherein filtering includes 
echo cancellation. 
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26. The method of Claim 24, wherein filtering includes 
NEXT cancellation. 

27. The method of Claim 24, wherein filtering includes 
5 baseline wander correction. 



28. A method of detecting symbols transmitted over a 
plurality of channels, comprising: 

receiving an input signal from each of the 
10 plurality of channels; 

filtering the input signal from each of the 
plurality of channels to obtain a filtered signal 
for each of the plurality of channels; 

digitizing the filtered signal from each of 
15 the plurality of channels to obtain a digitized 

signal for each of the plurality of channels; 

equalizing the digitized signal with a 
sequence detector from each of the plurality of 
channels to obtain an equalized signal from each 
2 0 of the plurality of channels; 

determining a multidimensional symbol from 
the digitized symbols from each of the plurality 
of channels. 



2 5 29. The method of Claim 28, wherein filtering includes 
echo cancellation. 



30. The method of Claim 28, wherein filtering includes 
NEXT cancellation. 



31. The method of Claim 28, wherein filtering includes 
baseline wander correction. 



32. The method of Claim 28, wherein equalizing the 
35 digitized signal includes: 
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computing a branch metric based on the 
digitized signal; 

computing a set of ACS results and a set of 
state metrics based on the branch metric; and 
5 computing a starting point based on the set 

of state metrics. 

33. The method of Claim 32, wherein the branch metric 
and ACS results are based on state reduction. 

10 

34. The method of Claim 32, further including 
computing a second set of ACS results and a set of 
differences . 

15 35. The method of Claim 34, wherein determining the 
multidimensional symbol includes 

tracing back based on the ACS results and the 
starting point on each of the plurality of 
channels to compute a symbol for each of the 
2 0 plurality of channels; 

determining which one of the plurality of 
channels is most likely to have an incorrect 
symbol ; 

forming a multidimensional symbol from the 

2 5 symbol for each of the plurality of channels; 

determining a parity of the multidimensional 
symbol ; 

replacing the symbol from the one of the 
plurality of channels which is most likely to have 

3 0 an incorrect symbol in the multidimensional symbol 

based on the parity of the multidimensional 
symbol . 
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DETECTOR FOR AN ETHERNET RECEIVER 

Peter J. Sallaway 
Sreen Raghavan 

5 

ABSTRACT 

A detector system for high-speed Ethernet LAN is 
described. One embodiment includes a detector system 

10 having N one dimensional sequence detector equalizers 

in combination with an N-dimensional traceback decoder. 
The detector system detects N-dimensional symbols 
transmitted over N separate transport channels to N 
one -dimensional receivers. In one embodiment, Gigabit 

15 Ethernet receiver includes a four-wire transport to 

four ID receivers and a 4D detector. The 4D detector 
in one embodiment is a parity code detector. In 
another embodiment, the 4D detector is a 4D trellis 
code detector. 
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